:root{--font-sans:"Outfit", "Kiwi Maru", system-ui, -apple-system, sans-serif;--text-color:#4a3e3d;--text-muted:#7d6e6d;--card-bg:#ffffffbf;--card-border:#fff6;--shadow-sm:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--bg-sunny:linear-gradient(135deg, #fff6e5 0%, #ffe9b3 100%);--bg-cloudy:linear-gradient(135deg, #edf2f4 0%, #cfd8dc 100%);--bg-rainy:linear-gradient(135deg, #e3f2fd 0%, #b0bec5 100%);--bg-snowy:linear-gradient(135deg, #f5f7fa 0%, #e4e8eb 100%);--bg-thunderstorm:linear-gradient(135deg, #ece9e6 0%, #b2b2b9 100%);--color-sunny:#ff9f1c;--color-cloudy:#90a4ae;--color-rainy:#2196f3;--color-snowy:#00bcd4;--color-thunderstorm:#673ab7;--accent-color:#e76f51;--radius-lg:24px;--radius-md:16px;--radius-sm:10px}@media (prefers-color-scheme:dark){:root{--text-color:#e2e8f0;--text-muted:#94a3b8;--card-bg:#1e293bb3;--card-border:#ffffff14;--bg-sunny:linear-gradient(135deg, #2d1a00 0%, #150a00 100%);--bg-cloudy:linear-gradient(135deg, #1c2321 0%, #0f111a 100%);--bg-rainy:linear-gradient(135deg, #0d1b2a 0%, #03071e 100%);--bg-snowy:linear-gradient(135deg, #1a2e35 0%, #0b1317 100%);--bg-thunderstorm:linear-gradient(135deg, #180e29 0%, #0a0413 100%)}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text-color);min-height:100dvh;transition:background .5s,color .3s;overflow-x:hidden}#root{justify-content:center;width:100%;min-height:100dvh;display:flex}.app-container{flex-direction:column;gap:20px;width:100%;max-width:540px;min-height:100dvh;padding:16px;transition:background .5s;display:flex;position:relative}.app-header{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.app-title-group{align-items:center;gap:8px;display:flex}.app-logo{width:36px;height:36px;box-shadow:var(--shadow-sm);border:2px solid #fff;border-radius:50%}.app-title{letter-spacing:-.5px;font-size:20px;font-weight:700}.location-selector{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.location-selector:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.cat-section{flex-direction:column;align-items:center;min-height:280px;padding:20px 0;display:flex;position:relative}.dialogue-balloon{max-width:85%;box-shadow:var(--shadow-md);text-align:center;color:#5c4d4c;background:#fff;border-radius:20px;margin-bottom:24px;padding:14px 20px;font-size:15px;font-weight:500;line-height:1.5;animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards popIn;position:relative}@media (prefers-color-scheme:dark){.dialogue-balloon{color:#f1f5f9;background:#1e293b}}.dialogue-balloon:after{content:"";border:10px solid #0000;border-top-color:#fff;border-bottom:0 solid #fff;width:0;display:block;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}@media (prefers-color-scheme:dark){.dialogue-balloon:after{border-color:#1e293b #0000}}.cat-image-container{justify-content:center;align-items:center;width:200px;height:200px;display:flex;position:relative}.cat-image{object-fit:contain;filter:drop-shadow(0 10px 8px #0000000f);width:100%;height:100%}.cat-float{animation:4s ease-in-out infinite catFloat}.cat-sleep{animation:5s ease-in-out infinite catSleep}.cat-shiver{animation:.5s ease-in-out infinite catShiver}.weather-details-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;gap:20px;padding:24px;display:flex}.weather-header{justify-content:space-between;align-items:flex-start;display:flex}.weather-temp-group{flex-direction:column;display:flex}.current-temp{align-items:flex-start;font-size:64px;font-weight:700;line-height:1;display:flex}.temp-unit{margin-top:6px;margin-left:2px;font-size:28px}.weather-label-group{align-items:center;gap:8px;margin-top:4px;display:flex}.weather-label{font-size:18px;font-weight:600}.temp-range{color:var(--text-muted);font-size:14px}.grid-details{border-top:1px solid var(--card-border);grid-template-columns:repeat(3,1fr);gap:12px;padding-top:16px;display:grid}.detail-item{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.detail-icon{opacity:.8;width:20px;height:20px}.detail-label{color:var(--text-muted);text-transform:uppercase;font-size:11px}.detail-value{font-size:15px;font-weight:600}.forecast-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:20px}.forecast-title{align-items:center;gap:8px;margin-bottom:14px;font-size:16px;font-weight:700;display:flex}.forecast-list{flex-direction:column;gap:12px;display:flex}.forecast-row{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:8px 0;display:flex}@media (prefers-color-scheme:dark){.forecast-row{border-bottom:1px solid #ffffff0a}}.forecast-row:last-child{border-bottom:none;padding-bottom:0}.forecast-date{width:80px;font-size:14px;font-weight:600}.forecast-weather{flex:1;align-items:center;gap:8px;padding-left:12px;display:flex}.forecast-icon{width:24px;height:24px}.forecast-pop{color:var(--color-rainy);font-size:11px;font-weight:600}.forecast-temps{justify-content:flex-end;gap:10px;width:80px;font-size:14px;font-weight:600;display:flex}.forecast-temp-max{color:var(--accent-color)}.forecast-temp-min{color:var(--text-muted)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-sunny);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);flex-direction:column;gap:20px;width:100%;max-width:540px;max-height:80vh;padding:24px;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp;display:flex;overflow-y:auto;box-shadow:0 -10px 25px #00000026}@media (prefers-color-scheme:dark){.modal-content{background:#0f172a}}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:18px;font-weight:700}.close-btn{cursor:pointer;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .2s;display:flex}@media (prefers-color-scheme:dark){.close-btn{color:#fff;background:#ffffff0d}}.close-btn:hover{background:#0000001a}.search-box-wrapper{gap:8px;display:flex;position:relative}.search-input{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--text-color);box-shadow:var(--shadow-sm);flex:1;padding:12px 16px;font-size:15px}.search-input:focus{border-color:var(--accent-color);outline:none}.search-results{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-sm);max-height:200px;box-shadow:var(--shadow-md);list-style:none;overflow-y:auto}.search-result-item{cursor:pointer;border-bottom:1px solid #0000000a;justify-content:space-between;padding:12px 16px;font-size:14px;display:flex}.search-result-item:hover{background:#00000005}@media (prefers-color-scheme:dark){.search-result-item:hover{background:#ffffff05}}.saved-locations-list{flex-direction:column;gap:8px;display:flex}.saved-location-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;transition:transform .15s;display:flex}.saved-location-item:hover{transform:translateY(-1px)}.saved-location-info{flex-direction:column;gap:2px;display:flex}.saved-location-name{font-size:15px;font-weight:600}.saved-location-coords{color:var(--text-muted);font-size:11px}.saved-location-actions{align-items:center;gap:12px;display:flex}.delete-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;padding:4px;transition:background .2s;display:flex}.delete-btn:hover{background:#ef44441a}.current-location-btn{background:var(--accent-color);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:15px;font-weight:600;transition:background .2s;display:flex}.current-location-btn:hover{opacity:.9}.loading-screen,.error-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:40px;display:flex}.spinner{border:4px solid #0000001a;border-top-color:var(--accent-color);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes catFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes catSleep{0%,to{transform:scale(1)}50%{transform:scale(.96)}}@keyframes catShiver{0%,to{transform:translate(0)rotate(0)}20%{transform:translate(-2px,1px)rotate(-.5deg)}40%{transform:translate(1px,-1px)rotate(.5deg)}60%{transform:translate(-1px,-1px)rotate(-.5deg)}80%{transform:translate(2px,1px)rotate(.5deg)}}@keyframes popIn{0%{opacity:0;transform:scale(.8)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}
