*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:system-ui,-apple-system,sans-serif;background:#1a1a2e;color:#e0e0e0}.app{display:flex;flex-direction:column;height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#16213e;border-bottom:2px solid #0f3460;flex-shrink:0}.header h1{font-size:1.3rem;color:#e0e0e0}.header__actions{display:flex;gap:.5rem}.main{display:flex;flex:1;overflow:hidden}.btn{padding:.4rem 1rem;border:1px solid #0f3460;border-radius:6px;background:#16213e;color:#e0e0e0;font-size:.9rem;cursor:pointer;transition:background .2s}.btn:hover{background:#0f3460}.btn--primary{background:#e94560;border-color:#e94560;color:#fff;font-weight:600}.btn--primary:hover{background:#c73652}.btn--sign-out{background:transparent;border-color:#555;color:#999;font-size:.75rem;padding:4px 10px}.btn--sign-out:hover{color:#fff;border-color:#999}.map{flex:1;position:relative;overflow:hidden;background:#111}.map__image{display:block;width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.map-dot{width:16px;height:16px;border-radius:50%;background:#ffffffbf;border:2px solid #fff;pointer-events:none;z-index:1;box-shadow:0 0 6px #00000080,0 0 12px #ffffff4d}.map-dot--occupied{background:#4ecca34d;border-color:#4ecca380;box-shadow:none}.map-dot--highlight{background:#4ecca3e6;border-color:#4ecca3;box-shadow:0 0 8px #4ecca3cc,0 0 16px #4ecca366;animation:dot-pulse 1s ease-in-out infinite}@keyframes dot-pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}}.bank{width:220px;flex-shrink:0;background:#16213e;border-left:2px solid #0f3460;display:flex;flex-direction:column;overflow:hidden}.bank__title{font-size:1rem;padding:.6rem .8rem .2rem;color:#e0e0e0}.bank__hint{font-size:.75rem;padding:0 .8rem .4rem;color:#888}.bank__list{flex:1;overflow-y:auto;padding:.4rem .6rem;display:flex;flex-direction:column;gap:.3rem}.bank__empty{padding:1rem;text-align:center;color:#4ecca3;font-weight:600}.bank__score{font-size:1.6rem;font-weight:700;padding:0 .8rem .5rem;color:#4ecca3}.bank__result{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.8rem}.bank__result--correct{background:#4ecca326}.bank__result--close{background:#f0c04026}.bank__result--wrong{background:#ff6b6b26}.bank__grade-label{font-weight:600}.bank__result--correct .bank__grade-label{color:#4ecca3}.bank__result--close .bank__grade-label{color:#f0c040}.bank__result--wrong .bank__grade-label{color:#ff6b6b}.bank__actions{padding:.6rem;flex-shrink:0}.label{display:inline-block;padding:.3rem .6rem;background:#ffffffeb;color:#1a1a2e;border-radius:999px;font-size:.75rem;font-weight:600;cursor:grab;-webkit-user-select:none;user-select:none;white-space:nowrap;touch-action:none;box-shadow:0 1px 3px #0000004d;transition:box-shadow .15s}.label:hover{box-shadow:0 2px 8px #0006}.label--placed{background:#fffc;font-size:.65rem;padding:.2rem .5rem;cursor:grab}.label--unlocked{background:#a0a0a099;color:#555;border:1px dashed rgba(100,100,100,.5);opacity:.7}.label--answer{background:#4ecca3e6;color:#111;cursor:default;pointer-events:none}.label--ghost{position:fixed;z-index:1000;pointer-events:none;opacity:.85;box-shadow:0 4px 16px #0006;transform:scale(1.05)}.label--correct{background:#4ecca3;color:#111;border:2px solid #2d9a6f}.label--close{background:#f0c040;color:#111;border:2px solid #c9a020}.label--wrong{background:#ff6b6b;color:#111;border:2px solid #d44}.btn--admin-active{background:#e94560;border-color:#e94560;color:#fff}.admin-row{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;font-size:.8rem;border-radius:4px;background:#ffffff0d}.admin-row__name{color:#e0e0e0}.admin-row__coords{color:#888;font-family:monospace;font-size:.7rem}.code-gate{display:flex;align-items:center;justify-content:center;height:100vh;background:#1a1a2e}.code-gate__card{background:#16213e;border:2px solid #0f3460;border-radius:12px;padding:2.5rem;max-width:400px;width:90%;text-align:center}.code-gate__title{font-size:1.6rem;color:#e0e0e0;margin-bottom:.5rem}.code-gate__subtitle{color:#888;font-size:.9rem;margin-bottom:1.5rem}.code-gate__email{color:#4ecca3;font-size:.8rem;margin-bottom:1rem}.code-gate__form{display:flex;gap:.5rem}.code-gate__input{flex:1;padding:.6rem 1rem;border:2px solid #0f3460;border-radius:6px;background:#1a1a2e;color:#e0e0e0;font-size:1rem;outline:none;transition:border-color .2s}.code-gate__input:focus{border-color:#4ecca3}.code-gate__btn{flex-shrink:0}.code-gate__error{color:#ff6b6b;font-size:.85rem;margin-top:1rem}.answers-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}@media(max-width:768px){.header{flex-direction:column;align-items:stretch;padding:.4rem .6rem;gap:.3rem}.header h1{font-size:1rem;text-align:center}.header__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.3rem}.header__actions .btn{font-size:.8rem;padding:.3rem .6rem}.main{flex-direction:column;overflow:visible}.map{flex:1;min-height:0;max-height:65vh}.bank{width:100%;flex:0 0 auto;min-height:80px;max-height:35vh;border-left:none;border-top:2px solid #0f3460;overflow-y:auto}.bank__list{flex-direction:row;flex-wrap:wrap;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:.6rem}.label--placed{font-size:.5rem;padding:.1rem .35rem}.answers-overlay .label--answer{font-size:.45rem;padding:.05rem .25rem;line-height:1.2}}
