:root{--ios-bg:linear-gradient(180deg, #ffb75e 0%, #6495ed 100%);--text-primary:#fff;--text-secondary:#fff9;--glass-bg:#00000026;--glass-border:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--ios-bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}#root{justify-content:center;width:100%;display:flex}.ios-weather-app{width:100%;max-width:430px;min-height:100vh;margin:0 auto;padding:3rem 1.25rem}.top-actions{align-items:flex-start;gap:1rem;margin-bottom:2.5rem;display:flex}.top-actions .city-selector{flex:1;margin-bottom:0}.view-toggle{cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#fff3;border:none;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .2s;display:flex}.view-toggle:hover{background:#ffffff4d}.dashboard-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.fav-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);text-align:center;cursor:pointer;border-radius:20px;padding:1.25rem;transition:all .3s}.fav-card:hover{background:#fff3;transform:translateY(-5px)}.delete-fav-btn{color:#fff;cursor:pointer;opacity:0;background:#0003;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.fav-card:hover .delete-fav-btn{opacity:1}.delete-fav-btn:hover{background:#ff3b30}.fav-card h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.5rem;font-size:1rem;font-weight:500;overflow:hidden}.fav-card-content img{filter:drop-shadow(0 4px 6px #0000001a);width:48px;height:48px}.fav-card-content h1{margin:.25rem 0;font-size:2.25rem;font-weight:300}.fav-card-content p{color:var(--text-secondary);text-transform:capitalize;font-size:.8rem}.city-selector{margin-bottom:2.5rem}.city-list{-ms-overflow-style:none;scrollbar-width:none;gap:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.city-list::-webkit-scrollbar{display:none}.city-button{border:1px solid var(--glass-border);color:#fff;white-space:nowrap;cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#0003;border-radius:20px;padding:.5rem 1rem;font-family:inherit;font-size:.95rem;transition:all .3s}.city-button:hover{background:#ffffff1a}.city-button.active{background:#ffffff4d;border-color:#ffffff80;font-weight:600}.add-city-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;font-size:1.25rem;transition:all .2s;display:flex}.add-city-btn:hover{background:#ffffff4d;transform:scale(1.1)}.search-overlay{-webkit-backdrop-filter:blur(10px);background:#0000004d;border-radius:12px;margin-top:1rem;padding:.75rem}.search-overlay input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:1rem}.suggestions-list{border-top:1px solid #ffffff1a;max-height:200px;margin-top:.5rem;overflow-y:auto}.suggestion-item{cursor:pointer;border-bottom:1px solid #ffffff0d;flex-direction:column;padding:.75rem .25rem;transition:background .2s;display:flex}.suggestion-item:hover{background:#ffffff1a}.suggestion-name{font-size:.95rem;font-weight:600}.suggestion-country{color:var(--text-secondary);font-size:.8rem}.status{text-align:center;color:var(--text-secondary);font-size:1.1rem;animation:1.5s infinite pulse}.current-weather{text-align:center;margin-bottom:3.5rem}.header-row{justify-content:center;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.fav-btn{cursor:pointer;background:0 0;border:none;align-items:center;padding:0;font-size:1.5rem;transition:transform .2s;display:flex}.fav-btn:hover{transform:scale(1.2)}.fav-btn.active{filter:drop-shadow(0 0 5px #ff00004d)}.city-name{letter-spacing:.5px;margin-bottom:0;font-size:2.25rem;font-weight:400}.current-temp{margin-bottom:0;margin-left:1.5rem;font-size:6.5rem;font-weight:200;line-height:1}.condition{text-transform:capitalize;margin-bottom:.25rem;font-size:1.3rem;font-weight:500}.high-low{font-size:1.15rem;font-weight:500}.hourly-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-radius:16px;margin-bottom:1rem;padding:1rem}.hourly-list{gap:1.25rem;padding-top:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.hourly-list::-webkit-scrollbar{display:none}.hourly-list{-ms-overflow-style:none;scrollbar-width:none}.hourly-item{flex-direction:column;align-items:center;min-width:45px;display:flex}.hourly-time{margin-bottom:.25rem;font-size:.95rem;font-weight:500}.hourly-icon{filter:drop-shadow(0 2px 4px #00000026);width:36px;height:36px;margin:.25rem 0}.hourly-temp{font-size:1.1rem;font-weight:600}.forecast-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-radius:16px;padding:1rem}.forecast-header{color:var(--text-secondary);border-bottom:1px solid var(--glass-border);align-items:center;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;font-size:.8rem;font-weight:600;display:flex}.icon-calendar{opacity:.7}.forecast-list{flex-direction:column;display:flex}.forecast-row-item{border-bottom:1px solid var(--glass-border);align-items:center;padding:.5rem 0;display:flex}.forecast-row-item:last-child{border-bottom:none;padding-bottom:0}.day-name{text-transform:capitalize;width:60px;font-size:1.1rem;font-weight:500}.day-icon{justify-content:center;width:40px;margin-left:.5rem;display:flex}.day-icon img{width:32px;height:32px}.min-temp,.max-temp{text-align:right;width:45px;font-size:1.25rem;font-weight:500}.min-temp{color:var(--text-secondary);margin-left:auto}.max-temp{color:#fff;margin-left:.75rem}.temp-bar-container{border-radius:2px;flex:1;height:4px;margin:0 .5rem;position:relative}.temp-bar-bg{background:#0003;border-radius:2px;width:100%;height:100%;position:absolute;top:0;left:0}.temp-bar{background:linear-gradient(90deg,#51ccff,#ff2d55);border-radius:2px;height:100%;position:absolute;box-shadow:0 0 4px #0000001a}.fade-in{animation:.6s cubic-bezier(.16,1,.3,1) forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}
