.ripple-background{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ripple{position:absolute;border:10px solid #F6FCFE;width:100px;height:100px;border-radius:50%;opacity:0;animation:ripple-wave 8s infinite linear;transform:translate(-50%,-50%)}.ripple:nth-child(2){animation-delay:2s}.ripple:nth-child(3){animation-delay:4s}@keyframes ripple-wave{0%{width:0px;height:0px;opacity:.8}to{width:1200px;height:1200px;opacity:0}}.homepage{position:relative;width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column}.homepage main{flex:1;display:flex;flex-direction:column;justify-content:space-around;align-items:center;z-index:2}.headings-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem}.homepage main h1{font-size:4rem;text-align:center;color:#39495c}.headings-wrapper h2{font-style:italic;color:#546b87}.homepage footer{text-align:center;padding:1rem;color:#39495c}button{border:2px solid #3A3A2F;padding:1rem 2rem;border-radius:50px;font-size:1.5rem;color:#3a3a2f;background-image:linear-gradient(#b1c965,#9dba41)}.level-selection-screen{height:100vh;width:100vw;position:relative;overflow-x:hidden;display:flex;flex-direction:column;align-items:center;padding:10rem;box-sizing:border-box}.back-arrow{position:fixed;top:20px;left:20px;background:none;border:none;color:#34495e;font-weight:700;cursor:pointer;z-index:100}.levels-container{width:100%;display:grid;align-items:center}.levels-container-wrapper{z-index:2;display:flex;flex-direction:column;gap:5rem;width:100%;max-width:600px;margin:auto}.level-node-wrapper{position:relative;display:flex;align-items:center;width:fit-content}.left-side{justify-content:flex-start;margin-left:auto}.right-side{justify-content:flex-end}.level-circle{width:120px;height:120px;border-radius:50%;background:#abca53;border:5px solid #F1F2F6;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 8px 15px #0000001a;transition:transform .2s;text-align:center;padding:10px}.level-circle.locked{background:#bdc3c7;border:5px solid #7D7E82;cursor:not-allowed}.level-circle:hover:not(.locked){transform:scale(1.1)}.active-ripple{box-shadow:0 0 0 10px #ffffff4d,0 0 0 20px #ffffff1a}.lock-icon{width:50%}.back-arrow{display:flex;align-items:center;gap:1rem;font-size:1.25rem}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:999;padding:20px}.level-selection__pop-up{background:#fff;max-width:500px;width:100%;padding:40px;border-radius:24px;box-shadow:0 20px 50px #0003;text-align:center;animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}.level-selection__pop-up h1{color:#2d3436;font-size:2rem;margin-bottom:10px}.level-selection__pop-up h2{color:#636e72;font-size:1.1rem;font-weight:500;font-style:italic;margin-bottom:30px;line-height:1.4}.pop-up__content{text-align:left;color:#2d3436;line-height:1.6}.level-selection__pop-up h3{margin-top:25px;color:#539bf7;font-size:1.2rem}.level-selection__pop-up ul{padding-left:20px;margin-top:15px}.level-selection__pop-up li{margin-bottom:12px}.level-selection__pop-up li span{font-weight:700;color:#ebc208}.pop-up__close-btn{margin-top:30px;background:#539bf7;color:#fff;border:none;padding:14px 40px;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,background .2s}.pop-up__close-btn:hover{background:#74b9ff;transform:translateY(-2px)}@keyframes popIn{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:800px){.left-side{margin-left:20px}.right-side{margin-right:20px}}.grid-section{display:grid;grid-template-areas:"tiles stats" "tiles palette" "tiles palette";padding:2rem}.tiles{grid-area:tiles;display:grid;background-color:#bad494;padding:1rem;border-radius:6px;gap:.5rem;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr)}.palette{grid-area:palette;display:flex;flex-direction:column;gap:20px;padding:20px;background:#fffc;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:100%;max-width:600px;box-shadow:0 4px 15px #0000000d;height:fit-content;place-self:center}.stats-container{grid-area:stats}.palette-items{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:1rem}.palette-item{padding:8px;background:#fff;border-radius:4px;cursor:grab;display:flex;flex-direction:column;gap:.25rem;align-items:center}.palette-item img{padding:.25rem;border:2px dotted #3A3A2E;border-radius:10px;width:65px}.tile{display:flex;align-items:center;justify-content:center;border-radius:.25rem;background-color:#f1e7d3}.tile.drag-over{outline:3px dashed #94886B}.tile.fixed{background:#d9cda0;box-shadow:inset 0 0 0 2px #00000008}.invalid-drop{animation:shake .3s ease-in-out}@keyframes shake{0%{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-3px)}to{transform:translate(0)}}.empty-placeholder{width:70%;height:70%;background:#ddcba0;border-radius:4px}.tile.radius-highlight{outline:4px solid rgba(0,171,22,.7);background:linear-gradient(180deg,#ffeb3b1f,#ffeb3b0a);position:relative}.tile.radius-highlight.negative{outline:4px solid rgba(237,5,24,.85);background:linear-gradient(180deg,#ff63471a,#ff63470a)}.radius-overlay{position:absolute;inset:0;border-radius:4px;box-shadow:0 0 0 2px #ffeb3b2e inset;pointer-events:none}.radius-overlay.negative{box-shadow:0 0 0 2px #ff634738 inset}.tile img{cursor:grab}.tile img:active{cursor:grabbing}.palette-item.disabled{opacity:.45;cursor:not-allowed}.palette-count{font-weight:700;margin-left:6px}.level-complete{position:fixed;top:0;left:0;z-index:9999999999999999;width:101vw;height:102vh;display:grid;place-content:center;background-color:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out forwards}.level-complete-card{background:#fff;max-width:500px;width:100%;padding:40px;border-radius:24px;box-shadow:0 20px 50px #0003;text-align:center;display:flex;flex-direction:column;gap:1rem;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.stats-container{display:flex;flex-direction:column;gap:20px;padding:20px;background:#fffc;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:100%;max-width:600px;box-shadow:0 4px 15px #0000000d;height:fit-content;place-self:center}.stat-header{display:flex;justify-content:space-between;margin-bottom:8px;font-weight:600;color:#2c3e50}.stat-label{display:flex;gap:1rem;align-items:center}.stat-label img{width:45px}.stat-label--happy img{width:40px;height:40px}.progress-track{position:relative;height:12px;background:#e0e0e0;border-radius:10px;overflow:hidden}.win-zone-marker{position:absolute;left:75%;width:25%;height:100%;background:#fff6;border-left:1px dashed rgba(0,0,0,.1);border-right:1px dashed rgba(0,0,0,.1);z-index:1}.progress-fill{height:100%;border-radius:10px;transition:width .6s cubic-bezier(.175,.885,.32,1.275);position:relative;z-index:2}.happiness-fill{background:linear-gradient(90deg,#ffce67,#ff9f43)}.environment-fill{background:linear-gradient(90deg,#55efc4,#00b894)}.economy-fill{background:linear-gradient(90deg,#74b9ff,#0984e3)}.over-optimized{filter:saturate(1.5);animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%{opacity:1}50%{opacity:.8}to{opacity:1}}.level-component{height:100vh;width:100vw;display:flex;flex-direction:column;padding:20px}.level-component h1{text-align:center;margin:.5rem;color:#38485c}.level-component .back-arrow{position:relative;top:0;left:0}.level-component .grid-section{flex:1}strong.h{color:#e8b917}strong.env{color:#07ba32}strong.econ{color:#539bf7}strong.underline{text-decoration:underline}*{padding:0;margin:0;box-sizing:border-box}#root{width:100vw;height:100vh;font-family:Gill Sans,Gill Sans MT,Calibri,Trebuchet MS,sans-serif;font-family:Varela Round,sans-serif;background-image:linear-gradient(#d3eef8,#bee1f1)}.small-screen-blocker{display:none}@media(max-width:900px){.small-screen-blocker{position:absolute;top:0;left:0;height:100vh;width:100vw;z-index:100;background-image:linear-gradient(#d3eef8,#bee1f1);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:5vh}.small-screen-blocker h1{max-width:60vw}.small-screen-blocker p{width:80vw;text-align:justify;max-width:500px}}
