body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.app{display:flex;justify-content:center;align-items:center;min-height:100vh}.container{max-width:800px;width:100%}.header{text-align:center;color:#fff;margin-bottom:30px;display:flex;flex-direction:column;align-items:center;gap:10px}.header-icon{animation:float 3s ease-in-out infinite}.header h1{font-size:2.5em;margin:10px 0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.header p{font-size:1.1em;opacity:.9}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.stats-bar{display:flex;justify-content:center;gap:20px;margin-top:15px;padding:12px 20px;background:#fff3;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-item{display:flex;align-items:center;gap:6px;color:#fff;font-size:.9em;font-weight:500}.stat-item svg{opacity:.8}.search-card{background:#fff;border-radius:20px;padding:30px;box-shadow:0 20px 60px #0000004d;margin-bottom:30px}.search-form{display:flex;gap:10px;margin-bottom:20px}.search-input{flex:1;padding:15px 20px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;transition:all .3s;font-family:inherit}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-button,.location-button{padding:15px 30px;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;gap:8px;white-space:nowrap}.search-button{background:linear-gradient(135deg,#667eea,#764ba2)}.location-button{background:linear-gradient(135deg,#43e97b,#38f9d7)}.search-button:hover,.location-button:hover:not(:disabled){transform:translateY(-2px)}.search-button:hover{box-shadow:0 10px 20px #667eea4d}.location-button:hover:not(:disabled){box-shadow:0 10px 20px #43e97b4d}.search-button:active,.location-button:active:not(:disabled){transform:translateY(0)}.location-button:disabled{opacity:.6;cursor:not-allowed}.location-status{background:#e3f2fd;color:#1976d2;padding:12px 20px;border-radius:10px;margin-bottom:15px;display:flex;align-items:center;gap:10px;border-left:4px solid #2196f3;animation:fadeIn .3s ease}.popular-cities{display:flex;flex-wrap:wrap;gap:10px}.city-chip{padding:8px 16px;background:#f5f5f5;border:none;border-radius:20px;font-size:14px;cursor:pointer;transition:all .2s;font-family:inherit}.city-chip:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.error-message{background:#fff3cd;color:#856404;padding:15px 20px;border-radius:10px;margin-top:20px;border-left:4px solid #ffc107}.loading{text-align:center;padding:40px;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d}.spinner{animation:spin 1s linear infinite;color:#667eea}.spinner-small{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading p{margin-top:20px;color:#666}.weather-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.weather-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.city-name{font-size:2.5em;color:#333;margin-bottom:5px}.country{font-size:1.2em;color:#888}.temp-main{text-align:center;margin:30px 0}.temperature{font-size:5em;font-weight:300;color:#667eea;margin-bottom:10px}.description{font-size:1.5em;color:#666;text-transform:capitalize}.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-top:30px}.detail-item{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px;border-radius:15px;text-align:center;transition:transform .2s;display:flex;flex-direction:column;align-items:center;gap:8px}.detail-item:hover{transform:translateY(-5px)}.detail-icon{color:#667eea}.detail-label{font-size:.9em;color:#666;text-transform:uppercase;letter-spacing:1px}.detail-value{font-size:1.8em;font-weight:600;color:#333}.timestamp{text-align:center;color:#888;font-size:.9em;margin-top:20px}@media(max-width:600px){.header h1{font-size:1.8em}.stats-bar{flex-direction:column;gap:8px;align-items:center}.temperature{font-size:3.5em}.city-name{font-size:1.8em}.weather-details{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.search-form{flex-direction:column}.search-input,.search-button,.location-button{width:100%;justify-content:center}}.google-weather-card{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 24px #0000000f;font-family:Roboto,-apple-system,BlinkMacSystemFont,sans-serif;color:#202124;margin-top:24px;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid #f1f3f4}.location-info{display:flex;align-items:center;color:#5f6368;font-size:14px}.dot-indicator{width:8px;height:8px;background-color:#4285f4;border-radius:50%;margin-right:12px;box-shadow:0 0 0 4px #4285f41a}.update-btn{background:#fff;border:1px solid #dadce0;border-radius:18px;padding:6px 16px;font-size:13px;font-weight:500;color:#1a73e8;cursor:pointer;display:flex;align-items:center;transition:all .2s}.update-btn:hover{background:#f8f9fa;border-color:#d2e3fc;color:#174ea6}.menu-btn{background:none;border:none;cursor:pointer;color:#5f6368;margin-left:12px;padding:8px;border-radius:50%;transition:background .2s}.menu-btn:hover{background-color:#f1f3f4}.main-weather-section{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.main-temp-group{display:flex;align-items:flex-start}.weather-icon-large img{width:80px;height:80px;margin-right:8px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.current-temp{font-size:72px;font-weight:400;line-height:1;letter-spacing:-2px}.unit-group{display:flex;margin-left:12px;margin-top:8px;font-size:18px;color:#70757a}.unit{cursor:pointer;transition:color .2s}.unit.active{color:#202124;font-weight:600}.separator{margin:0 6px;color:#dadce0}.weather-meta{font-size:14px;color:#5f6368;line-height:2;margin-left:32px;padding-left:32px;border-left:1px solid #dadce0}.weather-status-right{text-align:right;flex-grow:1}.status-title{font-size:24px;font-weight:400;margin:0 0 8px;color:#202124}.status-time{font-size:14px;color:#70757a;margin-bottom:4px}.status-description{font-size:18px;color:#3c4043;text-transform:capitalize}.weather-tabs{position:relative;border-bottom:1px solid #e8eaed;margin-bottom:0;display:flex;gap:32px;padding:0 8px}.tab-btn{background:none;border:none;font-size:14px;font-weight:500;color:#5f6368;padding:12px 4px;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.tab-btn:hover{color:#202124}.tab-btn.active{color:#1a73e8;border-bottom-color:#1a73e8}.tab-btn.active{color:#202124;border-bottom-color:#fdb813}.graph-area{padding:24px 0;background:linear-gradient(180deg,#fffcf5,#fff);border-radius:0 0 8px 8px;margin-bottom:24px;position:relative}.weather-graph-container::-webkit-scrollbar{height:6px}.weather-graph-container::-webkit-scrollbar-thumb{background:#dadce0;border-radius:3px}.weather-graph-container::-webkit-scrollbar-track{background:transparent}.forecast-area{border-top:1px solid #f1f3f4;padding-top:24px}.daily-forecast{display:flex;justify-content:space-between;overflow-x:auto;gap:8px;padding-bottom:8px}.daily-item{display:flex;flex-direction:column;align-items:center;min-width:64px;padding:12px 8px;border-radius:12px;transition:background .2s}.daily-item:hover{background-color:#f8f9fa}.day-name{font-size:14px;color:#3c4043;margin-bottom:12px;font-weight:500}.day-icon{margin-bottom:12px;color:#fdb813}.day-temps{font-size:14px;font-weight:500;display:flex;gap:8px}.max-temp{color:#202124}.min-temp{color:#70757a}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;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}
