:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#fff0f5;--page-padding-x: 4rem;--page-padding-y: 4rem;--layout-gap: 20px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-height:100vh;padding:var(--page-padding-y) var(--page-padding-x) calc(var(--page-padding-y) * 2.5);box-sizing:border-box;background-color:#fff0f5;background-image:url(/patterns/candy-field.png);background-size:550px 550px;background-repeat:repeat;background-attachment:fixed;background-position:center top}body.info-modal-open{overflow:hidden}h1{font-size:3.2em;line-height:1.1}#app{width:min(1200px,100%);min-height:calc(100vh - 420px);display:flex;justify-content:center;align-items:flex-start;gap:var(--layout-gap);margin:0 auto}#info-panel{width:360px;max-width:400px;max-height:95vh;display:flex;flex-direction:column;gap:0;padding:0;background:#fff5f5;color:#8b4557;border-radius:18px;box-shadow:0 12px 28px #8b45572e;position:relative;overflow:hidden}.info-panel__banner{width:100%;height:auto;display:block;margin:0;border-radius:18px 18px 0 0;object-fit:cover}.info-panel__content{padding:16px 22px 20px;display:flex;flex-direction:column;gap:16px;flex:1;overflow-y:auto}#info-panel p{margin:0;font-size:.98rem;line-height:1.5}.info-panel__body{display:flex;flex-direction:column;gap:12px}hr{border:none;border-top:1px solid rgba(139,69,87,.2);margin:12px 0}.friends-panel__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.friends-panel__header h2{margin:0;font-size:1.2rem;letter-spacing:.02em}.friends-panel__description{margin:0;font-size:.85rem;color:#8b4557d9}.friends-panel__items{display:flex;flex-direction:column;gap:6px}.info-panel__form{display:flex;flex-direction:column;gap:12px}.info-panel__form-row{display:flex;gap:8px;align-items:stretch}.info-panel__form-row input{flex:1;padding:.6em .8em;border-radius:10px;border:1px solid rgba(255,105,180,.35);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.info-panel__form-row button{padding:.6em .8em;border-radius:10px;background:#ff69b4;color:#fff;border:none;font-size:.95rem;font-weight:600;transition:background-color .2s,transform .1s;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.info-panel__form-row input:focus{border-color:#ff69b4;box-shadow:0 0 0 3px #ff69b433;outline:none}.info-panel__form-row button:hover{background:#ff1493}.info-panel__form-row button:active{transform:translateY(1px)}.info-panel__form-hint{margin:0;font-size:.85rem;color:#8b4557bf}.info-panel__credits{padding-top:12px;border-top:1px solid rgba(139,69,87,.2);font-size:.85rem;color:#8b4557bf;text-align:center}.info-panel__credits a{color:#ff69b4;text-decoration:none}.info-panel__credits a:hover{text-decoration:underline}.info-panel__logo{height:28px;width:auto;vertical-align:middle;border-radius:4px}.info-panel__form-status{min-height:1.25em;margin:0;font-size:.85rem;color:#8b4557a6}.info-panel__form-status[data-state=pending]{color:#8b4557cc}.info-panel__form-status[data-state=success]{color:#ff69b4;font-weight:600}.info-panel__form-status[data-state=error]{color:#a22626;font-weight:600}.info-panel__form-status[data-state=offline]{color:#92400e;font-weight:600}.info-panel__close{display:none;position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#ff69b41a;color:#8b4557;font-size:1.2rem;line-height:0;padding:0;cursor:pointer}.info-panel__close:hover{background:#ff69b433}.game-controls{position:absolute;top:12px;right:12px;display:flex;gap:8px;z-index:5}.control-toggle{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;border-radius:50%;border:none;background:#0000008c;color:#fff;box-shadow:0 6px 16px #00000040;transition:background-color .2s,transform .1s,opacity .15s;padding:0;cursor:pointer}.control-toggle:focus-visible{outline:3px solid rgba(255,255,255,.8);outline-offset:2px}.info-toggle{display:none}.sound-toggle{opacity:.9}.sound-toggle[data-state=muted]{opacity:.7;background-color:#00000059}.sound-toggle__glyph{font-size:1.05rem;line-height:1}.info-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#8b45578c;z-index:30}.info-backdrop[hidden]{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}#game-container{width:var(--game-width-px, 400px);height:var(--game-height-px, 500px);position:relative;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #0000004d}#pixi-screen{width:100%;height:100%;display:block}.game-stage{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0;width:min(100%,var(--game-width-px, 400px))}.game-goodies{width:100%;max-width:var(--game-width-px, 400px);padding:.65rem .85rem;border-radius:14px;border:1px solid rgba(255,105,180,.15);background:#ffffff9e;color:#8b4557;font-size:.95rem;font-weight:600;text-align:center;box-shadow:0 12px 24px #ff69b429;box-sizing:border-box}.game-goodies p{margin:0;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.45rem}.game-goodies__logo{height:1.1rem;width:auto;display:inline-block}.game-goodies__link{display:inline-flex;align-items:center;gap:.25rem;color:inherit;text-decoration:none;font-weight:700}.game-goodies__link-icon{font-size:.9rem;line-height:1}.game-goodies__link:focus-visible,.game-goodies__link:hover{text-decoration:underline}.game-over-form{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(320px,calc(100% - 32px));border-radius:18px;padding:20px 22px;box-shadow:0 20px 48px #8b455766;background:#fffffff2;color:#8b4557;display:flex;flex-direction:column;gap:12px;z-index:60;box-sizing:border-box;transition:opacity .25s ease,transform .25s ease}.game-over-form--dismissed{opacity:0;transform:translate(-50%,-60%);pointer-events:none}.game-over-form h3{margin:0;font-size:1.4rem}.game-over-form__description{margin:0;font-size:.9rem;color:#8b4557cc}.game-over-form__fields{display:flex;flex-direction:column;gap:10px}.game-over-form__fields label{font-size:.85rem;font-weight:600;letter-spacing:.02em}.game-over-form__fields input{width:100%;padding:.55em .8em;border-radius:12px;border:1px solid rgba(139,69,87,.25);font-size:.95rem;box-sizing:border-box;font-family:inherit}.game-over-form__fields input:focus{outline:none;border-color:#ff69b4;box-shadow:0 0 0 3px #ff69b433}.game-over-form__actions{display:flex;gap:10px}.game-over-form__actions button{flex:1;padding:.65em 1em;border-radius:12px;border:none;font-weight:600;cursor:pointer;font-size:.95rem;transition:background-color .2s ease,opacity .2s ease}.game-over-form__actions button[type=submit]{background:#ff69b4;color:#fff}.game-over-form__actions button[type=submit]:disabled{opacity:.7;cursor:not-allowed}.game-over-form__actions button[type=button]{background:#8b455714;color:#8b4557}.game-over-form__actions button[type=button]:disabled{opacity:.5;cursor:not-allowed}.game-over-form__status{min-height:1.2em;margin:0;font-size:.85rem;color:#8b4557cc}.game-over-form__status[data-state=error]{color:#b91c1c}.game-over-form__status[data-state=success]{color:#ff69b4}.game-over-form__status[data-state=skipped]{color:#8b4557}.game-over-form__status[data-state=offline]{color:#92400e;font-weight:600}#sidebar-panels{display:flex;flex-direction:column;gap:18px;width:280px;max-width:320px;flex-shrink:0;box-sizing:border-box;margin-left:auto;position:relative;z-index:2}#sidebar-panels>*{width:100%}.site-footer{--footer-art-width: clamp(150px, 18vw, 500px);width:min(100%,1180px);margin:4rem auto 0;background:linear-gradient(180deg,#fff5f5,#ffe4e9);border-radius:36px;border:2px solid rgba(255,182,193,.9);box-shadow:0 18px 40px #ff69b42e;display:grid;grid-template-columns:var(--footer-art-width) minmax(0,1fr) var(--footer-art-width);overflow:hidden;position:relative;isolation:isolate}.site-footer--no-art{grid-template-columns:1fr;text-align:center}.site-footer--no-art .site-footer__content{align-items:center}.site-footer--no-art .site-footer__social,.site-footer--no-art .site-footer__links{justify-content:center}.site-footer__art{background:linear-gradient(180deg,#fff5f5,#ffe4e9);display:flex;align-items:center;justify-content:center;align-self:center;justify-self:center;padding:1.25rem;aspect-ratio:2 / 3}.site-footer__art img{width:100%;height:100%;object-fit:cover;border-radius:24px;box-shadow:0 16px 24px #ff69b426}.site-footer__content{padding:2.75rem clamp(1.5rem,4vw,4rem);display:flex;flex-direction:column;gap:1.25rem;text-align:left}.site-footer__eyebrow{margin:0;font-size:.8rem;text-transform:uppercase;letter-spacing:.25em;color:#8b4557cc;display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.site-footer__logo{height:32px;width:auto;vertical-align:middle;border-radius:4px;margin-left:4px}.site-footer__title{margin:0;font-size:clamp(1.5rem,2.6vw,2.3rem);color:#8b4557}.site-footer__tagline{margin:0;font-size:1rem;color:#8b4557e6}.site-footer__social{list-style:none;display:flex;gap:1rem;margin:0;padding:0}.site-footer__social a{width:48px;height:48px;border-radius:16px;border:2px solid rgba(255,105,180,.15);background:#fff;display:inline-flex;align-items:center;justify-content:center;color:#ff69b4;box-shadow:0 6px 16px #ff69b41f;transition:transform .2s ease,box-shadow .2s ease}.site-footer__social a:hover{transform:translateY(-3px) rotate(-3deg);box-shadow:0 12px 22px #ff69b433}.site-footer__social svg{width:24px;height:24px}.site-footer__social svg rect,.site-footer__social svg circle{fill:none;stroke:currentColor;stroke-width:1.5}.site-footer__social svg path{fill:currentColor;stroke:none}.site-footer__social svg .icon-solid{fill:currentColor;stroke:none}.site-footer__logo-icon{width:28px;height:28px;border-radius:6px;border:2px solid white;box-shadow:0 0 0 1px #ff69b44d}.site-footer__links{display:flex;flex-wrap:wrap;gap:1.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.site-footer__links a{color:#8b4557;text-decoration:none;padding-bottom:2px;border-bottom:2px solid transparent;transition:border-color .2s ease,color .2s ease}.site-footer__links a:hover{border-color:#ff69b4;color:#ff1493}@media (max-width: 1100px){.site-footer{--footer-art-width: clamp(130px, 20vw, 170px);grid-template-columns:var(--footer-art-width) 1fr var(--footer-art-width)}.site-footer__content{padding:2.25rem 2rem}.site-footer__art{min-height:320px}}#friends-panel{background:#fff5f5;color:#8b4557;border-radius:18px;padding:18px;box-shadow:0 15px 26px #ff69b42e;display:flex;flex-direction:column;gap:12px;box-sizing:border-box}.score-item{display:flex;align-items:center;gap:10px;background:#ffffffb3;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:6px 10px;transition:background-color .25s}.friends-panel__items .score-item:nth-child(odd){background:#ffffffb3}.friends-panel__items .score-item:nth-child(2n){background:#efe8ff}.friends-panel__items .score-item:hover{background:#fff}.score-thumb{width:24px;height:24px;border-radius:50%;border:2px solid rgba(255,255,255,.5);flex:0 0 auto}.score-meta{display:flex;flex-direction:column;line-height:1.2}.score-name{font-weight:700;font-size:.9rem}.score-points{display:none}.score-value{margin-left:auto;font-size:1.4rem;font-weight:900;letter-spacing:.01em}#leaderboard-panel{width:100%;max-height:85vh;background:#572339f2;color:#ffe4e9;border-radius:18px;padding:20px 18px 18px;box-shadow:0 18px 32px #8b455773;display:flex;flex-direction:column;gap:12px;box-sizing:border-box}#leaderboard-panel h2{margin:0;font-size:1.4rem;letter-spacing:.04em;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.leaderboard-countdown{font-size:.85rem;font-weight:500;color:#ffe4e9d9}#leaderboard-list{display:flex;flex-direction:column;gap:8px;min-height:200px}.leaderboard-item{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:10px 12px;border-radius:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);transition:transform .15s ease,border-color .2s ease}.leaderboard-item:hover{transform:translateY(-2px);border-color:#fff3}.leaderboard-item.is-highlighted{border-color:#ffb6c1;box-shadow:0 0 12px #ffb6c159}.leaderboard-rank{width:28px;height:28px;border-radius:50%;background:#ffffff26;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.leaderboard-name{font-size:1rem;font-weight:600}.leaderboard-score{font-weight:800;font-size:1.25rem}.leaderboard-placeholder,.leaderboard-empty,.leaderboard-error{border-radius:14px;padding:16px 14px;background:#ffffff0d;border:1px dashed rgba(255,255,255,.15);text-align:center;font-size:.95rem}.leaderboard-offline-notice{margin-top:8px;padding:12px 14px;border-radius:14px;border:1px dashed rgba(255,255,255,.35);background:#ffffff14;font-size:.9rem;font-weight:600;text-align:center}.leaderboard-placeholder:after{content:"";display:block;width:100%;height:6px;margin-top:8px;border-radius:999px;background:linear-gradient(90deg,#ffffff1a,#ffffff59,#ffffff1a);animation:leaderboard-sheen 1.2s infinite ease-in-out}@keyframes leaderboard-sheen{0%{transform:translate(-40%)}to{transform:translate(40%)}}@media (max-width: 768px){:root{--page-padding-x: 1rem;--page-padding-y: 1.5rem;--layout-gap: 12px}.site-footer{grid-template-columns:1fr;text-align:center}.site-footer__art{display:none}.site-footer__content{padding:2.25rem 1.5rem 2.75rem;align-items:center}.site-footer__links,.site-footer__social{justify-content:center}#app{flex-direction:column;align-items:center;width:100%;min-height:auto;gap:var(--layout-gap)}#info-panel{display:none}#info-panel.is-active{display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,360px);max-height:90vh;z-index:40}#game-container{width:100%;max-width:var(--game-width-px, 400px);height:auto;aspect-ratio:var(--game-width, 400) / var(--game-height, 500)}#sidebar-panels{width:min(100%,var(--game-width-px, 400px));max-width:var(--game-width-px, 400px);margin:0 auto;box-sizing:border-box;gap:16px}#leaderboard-panel,#friends-panel{width:100%;max-width:var(--game-width-px, 400px);box-sizing:border-box;padding:16px}.info-toggle{display:inline-flex}.info-panel__close{display:inline-flex;align-items:center;justify-content:center}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #3178c6aa)}.card{padding:2em}.read-the-docs{color:#888}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#ff69b4ae}button.control-toggle{background-color:#0000008c;border:none}button.control-toggle:hover{border-color:transparent}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}button.control-toggle{background-color:#0000008c}}
