*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#1a1a1a;color:#eee;font-family:system-ui,sans-serif;display:flex;align-items:center;justify-content:center}.app{text-align:center;padding:0 8px}.app-header{margin-bottom:.5rem}.app-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.game-select-label{font-size:.9rem;color:#aaa}.game-select{margin-left:.25rem;padding:.25rem .5rem;font-size:.9rem;background:#333;color:#eee;border:1px solid #555;border-radius:4px;cursor:pointer}.game-wrapper{display:inline-block;padding:8px;background:#000;cursor:pointer;width:min(800px,100vw);max-width:100vw;aspect-ratio:4 / 3;max-height:min(600px,calc(100vh - 140px))}.game-wrapper canvas{display:block;width:100%;height:100%;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.end-game-btn{margin-top:8px;padding:6px 14px;font-size:.9rem;background:#444;color:#ccc;border:1px solid #666;border-radius:6px;cursor:pointer;-webkit-tap-highlight-color:transparent}.end-game-btn:hover{background:#555;color:#eee}.game-container{display:inline-flex;flex-direction:column;align-items:center;gap:8px}.kitty-placeholder{min-height:200px;display:flex;align-items:center;justify-content:center;color:#888;font-size:1rem}.red-dot-chaser-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.red-dot-controls{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:4px;width:140px;height:140px}.red-dot-btn{min-width:44px;min-height:44px;font-size:1.5rem;background:#333;color:#eee;border:2px solid #555;border-radius:8px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.red-dot-btn:hover{background:#444;border-color:#666}.red-dot-btn:active{background:#555}.red-dot-btn-up{grid-column:2;grid-row:1}.red-dot-btn-down{grid-column:2;grid-row:3}.red-dot-btn-left{grid-column:1;grid-row:2}.red-dot-btn-right{grid-column:3;grid-row:2}.orcas-are-jerks-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.orcas-controls{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:4px;width:140px;height:140px}.orcas-btn{min-width:44px;min-height:44px;font-size:1.5rem;background:#333;color:#eee;border:2px solid #555;border-radius:8px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.orcas-btn:hover{background:#444;border-color:#666}.orcas-btn:active{background:#555}.orcas-btn-up{grid-column:2;grid-row:1}.orcas-btn-down{grid-column:2;grid-row:3}.orcas-btn-left{grid-column:1;grid-row:2}.orcas-btn-right{grid-column:3;grid-row:2}.cat-vs-dog-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.cat-vs-dog-controls{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:4px;width:140px;height:140px}.cat-vs-dog-btn{min-width:44px;min-height:44px;font-size:1.5rem;background:#333;color:#eee;border:2px solid #555;border-radius:8px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.cat-vs-dog-btn:hover{background:#444;border-color:#666}.cat-vs-dog-btn:active{background:#555}.cat-vs-dog-btn-up{grid-column:2;grid-row:1}.cat-vs-dog-btn-down{grid-column:2;grid-row:3}.cat-vs-dog-btn-left{grid-column:1;grid-row:2}.cat-vs-dog-btn-right{grid-column:3;grid-row:2}.zookeeper-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.zookeeper-title{margin:0 0 .5rem;font-size:1.5rem}.zookeeper-desc{margin:0 0 .5rem;font-size:.9rem;color:#aaa;max-width:360px;text-align:center}.zookeeper-info{text-align:center}.zookeeper-info p{margin:.25rem 0;font-size:.9rem}.zookeeper-last-run{margin-top:.5rem}.zookeeper-start{margin-top:.75rem;padding:.5rem 1.25rem;font-size:1rem;background:#3d7a37;color:#fff;border:2px solid #4a8f42;border-radius:8px;cursor:pointer}.zookeeper-start:hover{background:#4a8f42}.zookeeper-header{display:flex;gap:1.5rem;justify-content:center;font-size:.95rem}.zookeeper-board-wrap{padding:8px;background:#111;border-radius:8px}.zookeeper-canvas{display:block;border-radius:4px}.fisherman-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.fisherman-title{margin:0 0 .5rem;font-size:1.5rem}.fisherman-desc{margin:0 0 .5rem;font-size:.9rem;color:#aaa;max-width:360px;text-align:center}.fisherman-info{text-align:center}.fisherman-info p{margin:.25rem 0;font-size:.9rem}.fisherman-start{margin-top:.75rem;padding:.5rem 1.25rem;font-size:1rem;background:#1a6fb5;color:#fff;border:2px solid #256399;border-radius:8px;cursor:pointer}.fisherman-start:hover{background:#256399}.fisherman-controls{font-size:.85rem;color:#888}.space-duck-hunter-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.space-duck-hunter-title{margin:0 0 .5rem;font-size:1.5rem}.space-duck-hunter-desc{margin:0 0 .5rem;font-size:.9rem;color:#aaa;max-width:360px;text-align:center}.space-duck-hunter-info{text-align:center}.space-duck-hunter-info p{margin:.25rem 0;font-size:.9rem}.space-duck-hunter-last-score,.space-duck-hunter-last-wave{margin-top:.25rem}.space-duck-hunter-start{margin-top:.75rem;padding:.5rem 1.25rem;font-size:1rem;background:#6b4c9a;color:#fff;border:2px solid #7c5cad;border-radius:8px;cursor:pointer}.space-duck-hunter-start:hover{background:#7c5cad}.space-duck-hunter-controls{font-size:.85rem;color:#888}.space-duck-hunter-controls-dpad{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto auto;gap:4px;width:180px}.space-duck-hunter-btn{min-width:44px;min-height:44px;font-size:1rem;background:#333;color:#eee;border:2px solid #555;border-radius:8px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.space-duck-hunter-btn:hover{background:#444;border-color:#666}.space-duck-hunter-btn:active{background:#555}.space-duck-hunter-btn-thrust{grid-column:2;grid-row:1}.space-duck-hunter-btn-left{grid-column:1;grid-row:2}.space-duck-hunter-btn-right{grid-column:3;grid-row:2}.space-duck-hunter-btn-fire{grid-column:1 / -1;grid-row:3;font-size:.95rem}.kitty-throw-container{display:inline-flex;flex-direction:column;align-items:center;gap:12px}.kitty-throw-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.kitty-throw-btn{min-width:56px;min-height:48px;font-size:1.25rem;background:#333;color:#eee;border:2px solid #555;border-radius:8px;cursor:pointer;padding:0 12px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.kitty-throw-btn:hover{background:#444;border-color:#666}.kitty-throw-btn:active{background:#555}.kitty-throw-btn-fire{min-width:80px;font-size:1rem}.app-footer{margin-top:12px;padding:8px 0}.app-footer-link{background:none;border:none;color:#aaa;font-size:.9rem;cursor:pointer;text-decoration:none;padding:0}.app-footer-link:hover{color:#eee;text-decoration:underline}.stats-page{max-width:900px;margin:0 auto;padding:16px;text-align:left}.stats-back{background:none;border:none;color:#aaa;font-size:.95rem;cursor:pointer;padding:0 0 12px;margin-bottom:8px}.stats-back:hover{color:#eee;text-decoration:underline}.stats-title{font-size:1.35rem;margin:0 0 1rem}.stats-loading,.stats-error,.stats-no-data{color:#888;margin:1rem 0}.stats-error{color:#e06060}.stats-summary{margin-bottom:2rem}.stats-summary h3,.stats-charts h3{font-size:1.1rem;margin:0 0 .5rem;color:#ccc}.stats-table{width:100%;border-collapse:collapse;font-size:.9rem}.stats-table th,.stats-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #333}.stats-table th{color:#aaa;font-weight:600}.stats-period-select{margin-bottom:1rem}.stats-period-select label{font-size:.9rem;color:#aaa}.stats-period-select select{margin-left:.5rem;padding:.25rem .5rem;font-size:.9rem;background:#333;color:#eee;border:1px solid #555;border-radius:4px;cursor:pointer}.stats-chart-wrap{width:100%;height:260px;margin-bottom:2rem}
