@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap");*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#0f1b33,#1a2d52 30%,#1e3c72 60%,#2a5298);background-size:200% 200%;animation:gradientShift 12s ease infinite;min-height:100dvh;display:flex;justify-content:center;align-items:center;color:#fff;overflow-x:hidden}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.container{text-align:center;padding:1.5rem;max-width:400px;width:100%;z-index:1}.container,.hero{position:relative}.hero{margin-bottom:1.5rem}.hero h1{font-size:2.5rem;font-weight:800;letter-spacing:-.5px;text-shadow:0 2px 12px rgba(0,0,0,.4)}.hero .subtitle,.hero h1{position:relative;z-index:1}.hero .subtitle{font-size:1rem;opacity:.6;margin-top:.5rem;font-weight:400}.hero-snowflake{width:160px;height:160px;margin:0 auto 1rem;display:block;opacity:.15;animation:snowflakeSpin 30s linear infinite;filter:drop-shadow(0 0 20px rgba(255,255,255,.1))}@keyframes snowflakeSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.header-compact{font-size:1.3rem;font-weight:700;margin-bottom:.75rem;opacity:.7;letter-spacing:-.3px}.input-card{background:hsla(0,0%,100%,.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;padding:.75rem;margin-bottom:1rem}.input-group{width:100%;margin-bottom:.6rem}input{width:100%;padding:.85rem 1rem;font-size:1.2rem;border:2px solid transparent;border-radius:10px;text-align:center;letter-spacing:3px;font-weight:700;font-family:Inter,sans-serif;transition:border-color .2s,box-shadow .2s;background:hsla(0,0%,100%,.92);color:#1e3c72}input::placeholder{color:#a0b0cc;font-weight:400;letter-spacing:0;font-size:.95rem}input:focus{outline:none;border-color:hsla(0,0%,100%,.5);box-shadow:0 0 0 3px hsla(0,0%,100%,.1)}.check-button{width:100%;padding:.85rem 1.5rem;font-size:1.05rem;background:#fff;color:#1e3c72;border:none;border-radius:10px;cursor:pointer;font-weight:700;font-family:Inter,sans-serif;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 10px rgba(0,0,0,.1)}.check-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px rgba(0,0,0,.2)}.check-button:active:not(:disabled){transform:translateY(0)}.check-button:disabled{opacity:.4;cursor:not-allowed}.result{background:hsla(0,0%,100%,.1);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid hsla(0,0%,100%,.12);border-radius:18px;padding:1.25rem 1.25rem 1rem;animation:slideUp .35s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.snow-icon{font-size:2.5rem;margin-bottom:.4rem}.snow-status{font-size:1.15rem;font-weight:700;margin-bottom:.4rem}.accumulation{font-size:2.8rem;font-weight:800;margin:.25rem 0 .1rem;text-shadow:0 0 30px hsla(0,0%,100%,.15);letter-spacing:-1px;line-height:1}.accumulation-label{font-size:.8rem;opacity:.6;font-weight:400}.no-snow{font-size:1.1rem;opacity:.85}.no-snow,.temp{font-weight:500}.temp{font-size:.9rem;opacity:.55;margin-top:.3rem}.storm-total{margin-top:1rem;padding:.85rem 1rem;background:linear-gradient(135deg,rgba(99,179,237,.2),rgba(144,205,244,.12));border:1px solid rgba(99,179,237,.25);border-radius:10px;position:relative;overflow:hidden}.storm-total:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(99,179,237,.6),transparent)}.storm-total-value{font-size:1.6rem;font-weight:800;letter-spacing:-.5px;line-height:1;color:#b8deff}.storm-total-label{font-size:.75rem;opacity:.7;margin-top:.25rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.shovel-check{margin-top:1rem;padding:.6rem .85rem;border-radius:8px;font-size:.85rem;font-weight:600}.shovel-yes{background:rgba(251,191,36,.15);border:1px solid rgba(251,191,36,.25);color:#fde68a}.shovel-no{background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.2);color:#a7f3d0}.forecast{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid hsla(0,0%,100%,.08)}.forecast-day{flex:1 1;padding:.6rem .4rem;border-radius:10px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.04);transition:transform .2s,background .2s}.forecast-day:hover{transform:translateY(-2px);background:hsla(0,0%,100%,.1)}.forecast-day.has-snow{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.1)}.forecast-label{font-size:.7rem;font-weight:600;margin-bottom:.3rem;opacity:.65;text-transform:uppercase;letter-spacing:.5px}.forecast-icon{font-size:1.2rem;margin-bottom:.2rem}.forecast-amount{font-size:.9rem;font-weight:700}.share-button{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.12);border-radius:8px;color:#fff;font-size:.8rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:background .2s,transform .15s}.share-button:hover{background:hsla(0,0%,100%,.18);transform:translateY(-1px)}.share-button:active{transform:translateY(0)}.share-button svg{width:14px;height:14px}.error{background:hsla(0,100%,70%,.15);border:1px solid hsla(0,100%,70%,.15);padding:.75rem;border-radius:10px;margin-bottom:.75rem;font-weight:500;font-size:.9rem}.loading{font-size:1rem;opacity:.6;font-weight:400}.footer{position:fixed;bottom:.5rem;left:0;right:0;font-size:.55rem;opacity:.2;line-height:1.5;text-align:center}.footer a{color:inherit;text-decoration:none}.footer a:hover{opacity:.8;text-decoration:underline}.snow-particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.snow-particles .flake{position:absolute;top:-20px;color:#fff;opacity:0;animation:snowfall linear infinite}@keyframes snowfall{0%{opacity:0;transform:translateX(0) rotate(0deg)}8%{opacity:.35}90%{opacity:.2}to{opacity:0;transform:translateX(30px) rotate(1turn);top:100vh}}.snow-particles .flake:first-child{left:3%;animation-duration:9s;animation-delay:0s;font-size:8px}.snow-particles .flake:nth-child(2){left:12%;animation-duration:11s;animation-delay:1.2s;font-size:12px}.snow-particles .flake:nth-child(3){left:25%;animation-duration:8s;animation-delay:3s;font-size:10px}.snow-particles .flake:nth-child(4){left:38%;animation-duration:10s;animation-delay:.5s;font-size:6px}.snow-particles .flake:nth-child(5){left:52%;animation-duration:12s;animation-delay:2.5s;font-size:9px}.snow-particles .flake:nth-child(6){left:65%;animation-duration:9s;animation-delay:4s;font-size:14px}.snow-particles .flake:nth-child(7){left:78%;animation-duration:11s;animation-delay:1.5s;font-size:7px}.snow-particles .flake:nth-child(8){left:90%;animation-duration:10s;animation-delay:3.5s;font-size:10px}.snow-particles .flake:nth-child(9){left:45%;animation-duration:13s;animation-delay:5s;font-size:5px}.snow-particles .flake:nth-child(10){left:70%;animation-duration:8s;animation-delay:.8s;font-size:11px}@media (max-width:480px){body{align-items:flex-start;padding-top:2rem}.container{padding:1rem;max-width:100%}.hero{margin-bottom:1.25rem}.hero h1{font-size:2rem}.hero .subtitle{font-size:.9rem}.hero-snowflake{width:120px;height:120px;margin-bottom:.75rem}.header-compact{font-size:1.1rem;margin-bottom:.5rem}.input-card{padding:.6rem;border-radius:14px;margin-bottom:.75rem}input{font-size:1.1rem;padding:.75rem}.check-button{font-size:1rem;padding:.75rem}.result{padding:1rem;border-radius:16px}.snow-icon{font-size:2rem;margin-bottom:.3rem}.snow-status{font-size:1.05rem}.accumulation{font-size:2.4rem}.storm-total{margin-top:.75rem;padding:.6rem}.storm-total-value{font-size:1.3rem}.forecast{margin-top:.75rem;padding-top:.75rem;gap:.4rem}.forecast-day{padding:.5rem .3rem}.forecast-icon{font-size:1.1rem}.forecast-amount{font-size:.85rem}.share-button{margin-top:.75rem;padding:.45rem .9rem;font-size:.75rem}}@media (max-height:700px){body{align-items:flex-start;padding-top:1rem}.hero-snowflake{width:100px;height:100px;margin-bottom:.5rem}.hero{margin-bottom:1rem}.result{padding:.9rem}.snow-icon{font-size:1.8rem;margin-bottom:.2rem}.accumulation{font-size:2.2rem}}