:root{--color-pink: #FF4DA1;--color-blue: #0A1E4B;--color-yellow: #FFD200;--color-paper: #F2EFE9;--color-ink-black: #1A1A1A;--color-tile-blue: #4D9FFF;--tile-blue: #4D9FFF;--tile-red: #FF4DA1;--tile-turquoise: #0A1E4B;--tile-yellow: #FFD200;--font-sans: "Space Grotesk", sans-serif;--font-mono: "Space Grotesk", sans-serif;--space-xs: 5px;--space-sm: 9px;--space-md: 18px;--space-lg: 28px;--space-xl: 37px;--shadow-sm: 3px 3px 0 var(--color-blue);--shadow-md: 5px 5px 0 var(--color-blue);--shadow-lg: 7px 7px 0 var(--color-blue);--tile-size: 74px;--tile-gap: 12px;--dot-size: 8px;--goal-offset: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-sans);background-color:var(--color-paper);color:var(--color-blue);height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column;overflow:hidden}body{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.game-screen,.tutorial-screen{user-select:none;-webkit-user-select:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-mono);font-weight:400;text-transform:uppercase;letter-spacing:.05em}.title-underline{position:relative}.title-underline:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:12px;background-color:var(--color-yellow);z-index:-1}.game-header{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) var(--space-md);gap:var(--space-sm);position:sticky;top:0;z-index:1000;background-color:var(--color-paper);width:100%}.game-header__title{font-family:var(--font-mono);font-size:28px;font-weight:400;color:var(--color-blue);letter-spacing:.1em}.game-header__status{font-family:var(--font-mono);font-size:14px;font-weight:700;color:#fff;background-color:var(--color-pink);padding:6px 20px;border-radius:4px;letter-spacing:.1em}.tile{width:var(--tile-size);height:var(--tile-size);border-radius:8px;border:3px solid var(--color-blue);padding:6px;position:relative;box-shadow:var(--shadow-sm);cursor:default;transition:transform .15s,box-shadow .15s}.tile--dark{border-color:var(--color-paper)}.tile--selectable{cursor:pointer;transform:translate(-2px,-2px);box-shadow:var(--shadow-md)}.tile--selectable:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--color-blue)}.tile__cost{position:absolute;top:5px;left:7px;text-align:left;font-family:var(--font-mono);font-weight:400;font-size:21px;line-height:23px}.tile__cost--dark{color:#fff}.tile__cost--light{color:var(--color-blue)}.goal-anchor{position:absolute;display:flex;justify-content:center;width:calc(var(--dot-size) * 3)}.goal-anchor--tr{top:var(--goal-offset);right:var(--goal-offset)}.goal-anchor--br{bottom:var(--goal-offset);right:var(--goal-offset)}.goal-anchor--bl{bottom:var(--goal-offset);left:var(--goal-offset)}.goal-group{position:relative;display:flex;align-items:center;justify-content:center}.dots-container{position:relative}.dots-container--2{width:calc(var(--dot-size) * 2);height:calc(var(--dot-size) * 2)}.dots-container--4{width:calc(var(--dot-size) * 2 + 2px);height:calc(var(--dot-size) * 2 + 2px)}.dot{position:absolute;width:var(--dot-size);height:var(--dot-size);border-radius:50%;border:1px solid var(--color-blue)}.dot--center{top:50%;left:50%;transform:translate(-50%,-50%)}.dot--tl{top:0;left:0}.dot--tr{top:0;right:0}.dot--bl{bottom:0;left:0}.dot--br{bottom:0;right:0}.dot--tc{top:0;left:50%;margin-left:calc(var(--dot-size) / -2)}.dot--dark-tile{border-color:var(--color-paper)}.dot--completed{opacity:0;transition:opacity .2s ease}.goal-group:hover .dot--completed{opacity:1}.completed-token{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;transition:opacity .2s ease}.completed-token:hover{opacity:0}.disc-token{width:calc(var(--dot-size) * 2);height:calc(var(--dot-size) * 2);border-radius:50%;border:2px solid white;box-shadow:1px 1px #0000004d}.empty-slot{width:var(--tile-size);height:var(--tile-size);border-radius:50%;border:2px dashed var(--color-blue);display:flex;justify-content:center;align-items:center;background-color:transparent;transition:background-color .15s}.empty-slot--valid{background-color:#ffd20066;cursor:pointer;border-color:var(--color-pink)}.empty-slot--valid:hover{background-color:#ffd20099}.empty-slot__plus{color:var(--color-pink);font-size:20px;font-family:var(--font-mono);font-weight:400}.moon-wheel{padding:10px}.moon-wheel__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--tile-gap);max-width:480px}.moon-wheel__slot{position:relative;width:var(--tile-size);height:var(--tile-size)}.moon-wheel__marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200}.moon-token{width:37px;height:37px;border-radius:50%;background-color:var(--color-yellow);border:3px solid var(--color-blue);display:flex;justify-content:center;align-items:center;box-shadow:var(--shadow-sm);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.moon-track--compact{background-color:transparent;border:none;padding:0;box-shadow:none;width:100%;max-width:520px}.moon-track--compact .moon-track__grid{display:flex;gap:4px;grid-template-columns:none;margin-bottom:0}.moon-track--compact .moon-track__grid--2-rows{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:4px}.moon-track--compact .moon-track__cell{aspect-ratio:1;width:100%;background-color:#fff;border:1px solid var(--color-blue);position:relative}.moon-track--compact .moon-track__cell-number{font-size:10px;top:2px;left:3px;font-weight:700}.moon-track__cell{width:37px;height:37px;border:1px solid var(--color-blue);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background-color:var(--color-paper)}.moon-track__cell-number{font-family:var(--font-mono);font-size:11px;color:var(--color-blue);opacity:.5;position:absolute;top:1px;left:2px}.moon-track__cell-tokens{display:flex;gap:2px;align-items:center;justify-content:center}.moon-track__token{width:12px;height:12px;border-radius:50%;border:1px solid white}.moon-track__token--blink{animation:token-blink .8s ease-in-out infinite alternate;box-shadow:0 0 8px currentColor}@keyframes token-blink{0%{opacity:1;transform:scale(1)}to{opacity:.4;transform:scale(1.3)}}.moon-track__scores{display:flex;justify-content:center;gap:40px;margin-top:12px;padding-top:8px;border-top:1px dashed var(--color-blue);width:100%}.moon-track__score-item{display:flex;align-items:center;gap:8px}.moon-track__score-dot{width:8px;height:8px;border-radius:50%;border:1px solid white}.moon-track__score-label{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--color-blue)}.player-grid{background-color:#fff;border-radius:4px;border:3px solid var(--color-blue);padding:var(--space-md);box-shadow:var(--shadow-lg);transition:width .3s ease,height .3s ease;overflow:visible;min-width:200px;min-height:200px;position:relative;z-index:1}.player-grid--active{box-shadow:6px 6px 0 var(--color-pink)}.player-grid__header{display:flex;justify-content:flex-start;align-items:center;padding-bottom:var(--space-sm);margin-bottom:var(--space-sm);gap:var(--space-sm)}.player-grid__label{color:var(--color-blue);font-size:12px;font-family:var(--font-mono);font-weight:700;letter-spacing:.05em}.player-grid__active-dot{width:8px;height:8px;border-radius:50%;background-color:var(--color-pink)}.player-grid__content{display:flex;justify-content:center}.player-grid__tiles{display:flex;flex-direction:column}.player-grid__row{display:flex}.player-grid__cell{margin:2px}.game-screen{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}.game-screen__content{flex:1;overflow-y:auto;padding:0 var(--space-md) var(--space-md) var(--space-md);scroll-behavior:smooth}.game-screen__layout{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.game-screen__market-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;position:sticky;top:0;z-index:900;background-color:var(--color-paper);padding:var(--space-md)}.game-screen__market-container:after{content:"";position:absolute;top:100%;left:0;right:0;height:5px;background:linear-gradient(to bottom,var(--color-paper) 0%,rgba(242,239,233,.9) 30%,transparent 100%);pointer-events:none;z-index:910;opacity:0;transition:opacity .3s ease}.game-screen__market-container.is-scrolled:after{opacity:1}.game-screen__market-container>*{position:relative;z-index:2}.game-screen__top-row{display:none}.game-screen__bottom-row{display:flex;align-items:flex-start;justify-content:center;gap:40px;width:100%;flex-wrap:wrap}.game-screen__reset-btn{position:fixed;bottom:20px;right:20px;background-color:var(--color-blue);color:#fff;padding:10px 20px;border:none;border-radius:4px;font-family:var(--font-mono);font-weight:700;font-size:14px;cursor:pointer;box-shadow:4px 4px 0 var(--color-yellow);z-index:100;transition:transform .1s,box-shadow .1s}.game-screen__reset-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--color-yellow)}.modal-overlay{position:fixed;inset:0;background-color:#0a1e4bcc;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:#fff;border:3px solid var(--color-blue);border-radius:4px;padding:var(--space-xl);max-width:400px;box-shadow:var(--shadow-lg);text-align:center}.modal__title{font-family:var(--font-mono);font-size:24px;margin-bottom:var(--space-md);color:var(--color-blue)}.modal__message{font-size:14px;margin-bottom:var(--space-lg);color:var(--color-blue);line-height:1.5}.modal__actions{display:flex;gap:var(--space-md);justify-content:center}.btn{font-family:var(--font-mono);font-weight:700;text-transform:uppercase;padding:var(--space-sm) var(--space-lg);border:3px solid var(--color-blue);border-radius:4px;cursor:pointer;transition:transform .1s,box-shadow .1s;font-size:14px}.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-md)}.btn-primary{background-color:var(--color-blue);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary{background-color:#fff;color:var(--color-blue);box-shadow:var(--shadow-sm)}.menu-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-xl);padding:var(--space-xl)}.menu-screen__title{font-family:var(--font-mono);font-size:28px;font-weight:400;color:var(--color-blue);letter-spacing:.1em}.menu-screen .btn-primary{background-color:var(--color-blue);color:#fff;box-shadow:4px 4px 0 var(--color-yellow);transition:transform .1s,box-shadow .1s}.menu-screen .btn-primary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--color-yellow)}.menu-screen__button-group{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:250px}.menu-screen__button-group .btn{margin-top:0!important;width:100%}.menu-screen__subtitle{font-family:var(--font-mono);font-size:14px;color:var(--color-blue);opacity:.7;text-transform:uppercase;letter-spacing:.1em}.settings-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-xl);padding:var(--space-xl)}.tutorial-screen{position:relative;flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;background-color:var(--color-paper)}.tutorial-overlay{position:fixed;inset:0;background-color:#000000d9;z-index:1500;display:flex;justify-content:center;align-items:center;pointer-events:none;transition:background-color .4s ease}.tutorial-instruction{background-color:#fff;border:4px solid var(--color-blue);border-radius:8px;padding:var(--space-lg);max-width:450px;box-shadow:10px 10px 0 var(--color-blue);text-align:center;pointer-events:auto;z-index:2000;position:absolute;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.tutorial-instruction--top{top:10%}.tutorial-instruction--bottom{bottom:10%}.tutorial-instruction--center{top:50%;transform:translateY(-50%)}.tutorial-instruction__text{font-family:var(--font-mono);font-size:16px;line-height:1.6;color:var(--color-blue);margin-bottom:var(--space-md)}.tutorial-highlight{position:relative;z-index:1600!important;pointer-events:auto!important;animation:tutorial-pulse 2s infinite;border-radius:12px}.tutorial-highlight--no-pulse{animation:none!important;box-shadow:none!important}.tutorial-highlight--no-shadow{box-shadow:none!important}.tutorial-dim{opacity:.2;pointer-events:none;transition:opacity .4s ease}.tutorial-grey-out{filter:grayscale(1) opacity(.3);pointer-events:none}.tutorial-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:32px;font-weight:700;pointer-events:none;z-index:100;text-shadow:0 0 10px rgba(255,255,255,.8)}.tutorial-marker--plus{color:var(--color-green)}.tutorial-marker--plus:after{content:"+"}.tutorial-marker--cross{color:var(--color-red);transform:translate(-50%,-50%) rotate(45deg)}.tutorial-marker--cross:after{content:"+"}@keyframes tutorial-snap{0%{transform:scale(1.5);opacity:0;filter:brightness(2)}to{transform:scale(1);opacity:1;filter:brightness(1)}}.tutorial-snap-animation{animation:tutorial-snap .3s ease-out}@keyframes tutorial-pulse{0%{box-shadow:0 0 #ff4da199,0 0 #ffd20066}50%{box-shadow:0 0 0 20px #ff4da100,0 0 0 30px #ffd20000}to{box-shadow:0 0 #ff4da100,0 0 #ffd20000}}.tutorial-step-indicator{position:absolute;top:20px;left:20px;font-family:var(--font-mono);font-size:12px;background-color:var(--color-pink);color:#fff;padding:4px 10px;border-radius:4px}.settings-screen__title{font-family:var(--font-mono);font-size:28px;font-weight:400;color:var(--color-blue);letter-spacing:.1em;margin-bottom:var(--space-lg)}.settings-screen__options{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:400px}.settings-option{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background-color:#fff;border:3px solid var(--color-blue);border-radius:4px}.settings-option__label{font-family:var(--font-mono);font-weight:700;text-transform:uppercase;font-size:14px;color:var(--color-blue)}.lobby-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-lg);padding:var(--space-xl)}.lobby-screen__title{font-family:var(--font-mono);font-size:28px;font-weight:400;color:var(--color-blue);letter-spacing:.1em;margin-bottom:var(--space-sm)}.lobby-screen__name-section{display:flex;flex-direction:column;gap:var(--space-xs);width:100%;max-width:300px}.lobby-screen__label{font-family:var(--font-mono);font-size:12px;font-weight:700;text-transform:uppercase;color:var(--color-blue)}.lobby-screen__name-input{font-family:var(--font-mono);font-size:16px;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-blue);border-radius:4px;background-color:#fff;color:var(--color-blue);text-align:center}.lobby-screen__name-input:focus{outline:none;box-shadow:var(--shadow-sm)}.lobby-screen__error{background-color:var(--color-pink);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:4px;font-family:var(--font-mono);font-size:12px;text-align:center;max-width:300px}.lobby-screen__card{background-color:#fff;border:3px solid var(--color-blue);border-radius:8px;padding:var(--space-lg);width:100%;max-width:300px;text-align:center;box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .15s}.lobby-screen__card:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}.lobby-screen__card-icon{font-size:32px;margin-bottom:var(--space-sm)}.lobby-screen__card-title{font-family:var(--font-mono);font-size:18px;color:var(--color-blue);margin-bottom:var(--space-xs)}.lobby-screen__card-description{font-family:var(--font-mono);font-size:12px;color:var(--color-blue);opacity:.7;margin-bottom:var(--space-md)}.lobby-screen__join-row{display:flex;gap:var(--space-sm)}.lobby-screen__code-input{flex:1;font-family:var(--font-mono);font-size:16px;font-weight:700;padding:var(--space-sm);border:2px solid var(--color-blue);border-radius:4px;text-align:center;text-transform:uppercase;letter-spacing:.2em}.lobby-screen__code-input:focus{outline:none;border-color:var(--color-pink)}.lobby-screen__back-btn{background-color:transparent;border:none;color:var(--color-blue);font-family:var(--font-mono);font-size:14px;cursor:pointer;text-decoration:underline;margin-top:var(--space-md)}.lobby-screen__back-btn:hover{color:var(--color-pink)}.waiting-room{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-lg);padding:var(--space-xl)}.waiting-room__title{font-family:var(--font-mono);font-size:24px;font-weight:400;color:var(--color-blue);letter-spacing:.1em;text-align:center}.waiting-room__loading{font-family:var(--font-mono);font-size:18px;color:var(--color-blue);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.waiting-room__error{background-color:var(--color-pink);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:4px;font-family:var(--font-mono);font-size:12px;text-align:center;max-width:300px}.waiting-room__code-section{text-align:center}.waiting-room__code-label{font-family:var(--font-mono);font-size:14px;color:var(--color-blue);margin-bottom:var(--space-sm)}.waiting-room__code-box{display:flex;align-items:center;gap:var(--space-md);background-color:#fff;border:3px solid var(--color-blue);border-radius:8px;padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-md)}.waiting-room__code{font-family:var(--font-mono);font-size:28px;font-weight:700;letter-spacing:.2em;color:var(--color-blue)}.waiting-room__copy-btn{background-color:var(--color-yellow);border:2px solid var(--color-blue);border-radius:4px;padding:var(--space-xs) var(--space-sm);font-family:var(--font-mono);font-size:12px;font-weight:700;cursor:pointer;transition:transform .1s}.waiting-room__copy-btn:hover{transform:scale(1.05)}.waiting-room__players{background-color:#fff;border:3px solid var(--color-blue);border-radius:8px;padding:var(--space-lg);width:100%;max-width:300px;box-shadow:var(--shadow-sm)}.waiting-room__players-title{font-family:var(--font-mono);font-size:14px;color:var(--color-blue);text-align:center;margin-bottom:var(--space-md)}.waiting-room__player{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px dashed var(--color-blue)}.waiting-room__player:last-child{border-bottom:none}.waiting-room__player--waiting{opacity:.5}.waiting-room__player-icon{font-size:16px;width:24px;text-align:center}.waiting-room__player-name{flex:1;font-family:var(--font-mono);font-size:14px;color:var(--color-blue)}.waiting-room__player-role{font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;background-color:var(--color-blue);color:#fff;padding:2px 6px;border-radius:4px}.waiting-room__actions{display:flex;gap:var(--space-md)}.game-screen__loading{display:flex;justify-content:center;align-items:center;height:100%;font-family:var(--font-mono);font-size:18px;color:var(--color-blue)}.game-screen__error-overlay{position:fixed;inset:0;background-color:#0a1e4be6;display:flex;justify-content:center;align-items:center;z-index:2000}.game-screen__error-content{background-color:#fff;border:3px solid var(--color-blue);border-radius:8px;padding:var(--space-xl);text-align:center;box-shadow:var(--shadow-lg)}.game-screen__error-content p{font-family:var(--font-mono);font-size:16px;color:var(--color-blue);margin-bottom:var(--space-lg)}@supports (height: 100dvh){html,body,#root,.tutorial-screen{height:100dvh}.menu-screen,.settings-screen,.lobby-screen,.waiting-room{min-height:100dvh}}@media(max-width:900px){:root{--tile-size: 56px;--tile-gap: 8px;--dot-size: 7px;--goal-offset: 6px}}@media(max-width:640px){:root{--tile-size: 44px;--tile-gap: 6px;--dot-size: 6px;--goal-offset: 4px}.game-header{padding:var(--space-sm);gap:var(--space-xs)}.game-header__title{font-size:20px}.game-header__status{font-size:10px;padding:4px 10px;text-align:center;line-height:1.6}.game-screen__content{padding:0 var(--space-sm) var(--space-sm) var(--space-sm)}.game-screen__market-container{padding:var(--space-sm)}.game-screen__bottom-row{gap:var(--space-md)}.player-grid{padding:var(--space-sm);min-width:0;min-height:0;max-width:100%;overflow-x:auto}.player-grid__content{justify-content:flex-start;justify-content:safe center}.tile{border-width:2px;border-radius:6px;padding:3px}.tile__cost{font-size:13px;line-height:15px;top:3px;left:4px}.empty-slot__plus{font-size:14px}.moon-track--compact{max-width:100%}.moon-track__scores{gap:16px;margin-top:8px}.game-screen__reset-btn{bottom:10px;right:10px;padding:8px 12px;font-size:11px}.modal{max-width:calc(100vw - 32px);padding:var(--space-lg)}.tutorial-instruction{max-width:calc(100vw - 32px)}}
