.auth-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.auth-container{background:#2d2d44;border:4px solid #4a4e69;box-shadow:8px 8px #0006;padding:40px;max-width:420px;width:100%;text-align:center}.auth-title{font-size:24px;color:#ffd60a;margin-bottom:8px;text-shadow:3px 3px 0 #b89a00;display:flex;align-items:center;justify-content:center;gap:12px}.marble-showcase{position:relative;height:80px;margin-bottom:16px}.floating-marble{position:absolute;animation:float 3s ease-in-out infinite}.marble-1{left:15%;top:10%;animation-delay:0s}.marble-2{right:15%;top:20%;animation-delay:.5s}.marble-3{left:35%;top:30%;animation-delay:1s}.marble-4{right:35%;top:5%;animation-delay:1.5s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-8px) rotate(10deg)}50%{transform:translateY(-12px) rotate(0)}75%{transform:translateY(-8px) rotate(-10deg)}}.title-text{background:linear-gradient(135deg,#ffd60a,#ff6b6b,#4ade80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite;background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.feature-highlights{display:flex;justify-content:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.feature-item{display:flex;align-items:center;gap:6px;font-size:8px;color:#9d9dba;background:#4a4e694d;padding:6px 10px;border-radius:4px}.feature-icon{font-size:12px}.marble-icon{font-size:28px;animation:bounce 1s ease infinite}.marble-icon:last-child{animation-delay:.5s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.auth-subtitle{color:#9d9dba;font-size:12px;margin-bottom:32px;letter-spacing:2px}.auth-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.auth-option-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 20px;font-family:"Press Start 2P",monospace;font-size:10px;border:3px solid;cursor:pointer;transition:all .2s ease;position:relative}.auth-option-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px #0000004d}.auth-option-btn:active:not(:disabled){transform:translateY(0);box-shadow:none}.auth-option-btn:disabled{opacity:.6;cursor:not-allowed}.auth-option-btn.google{background:#fff;color:#333;border-color:#ddd}.auth-option-btn.google:hover:not(:disabled){border-color:#4285f4}.google-icon{width:20px;height:20px}.auth-option-btn.email{background:#3d5a80;color:#fff;border-color:#2c4a6e}.auth-option-btn.email:hover:not(:disabled){background:#4a6fa5}.email-icon{font-size:16px}.auth-divider{display:flex;align-items:center;margin:8px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:2px;background:#4a4e69}.auth-divider span{padding:0 16px;color:#6c6c8a;font-size:10px}.auth-option-btn.quickplay{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border-color:#16a34a;flex-direction:column;gap:4px}.auth-option-btn.quickplay:hover:not(:disabled){background:linear-gradient(135deg,#5eeb92,#2dd667)}.play-icon{font-size:16px}.quickplay-note{font-size:7px;opacity:.8}.auth-info{margin-top:24px;padding-top:16px;border-top:2px solid #4a4e69}.auth-info p{color:#6c6c8a;font-size:8px;margin:4px 0}.auth-error{color:#ff6b6b;font-size:9px;margin:12px 0;padding:8px;background:#ff6b6b1a;border:2px solid #ff6b6b}.back-btn{background:none;border:none;color:#9d9dba;font-family:"Press Start 2P",monospace;font-size:10px;cursor:pointer;margin-bottom:20px;padding:8px;transition:color .2s}.back-btn:hover{color:#ffd60a}.auth-section-title{font-size:16px;color:#ffd60a;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:10px}.auth-section-desc{color:#9d9dba;font-size:9px;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-input{font-family:"Press Start 2P",monospace;font-size:10px;padding:14px 16px;background:#1a1a2e;border:3px solid #4a4e69;color:#fff;outline:none;transition:border-color .2s}.auth-input:focus{border-color:#ffd60a}.auth-input::placeholder{color:#6c6c8a}.quickplay-info{color:#6c6c8a;font-size:8px;margin-top:16px}.auth-switch{color:#9d9dba;font-size:8px;margin-top:16px}.auth-switch button{background:none;border:none;color:#ffd60a;font-family:"Press Start 2P",monospace;font-size:8px;cursor:pointer;text-decoration:underline}.auth-switch button:hover{color:#ffe44d}.welcome-back{background:linear-gradient(180deg,#2d2d44,#252538)}.welcome-header{margin-bottom:8px}.welcome-name-section{display:flex;align-items:center;justify-content:center;gap:12px;margin:12px 0 16px}.welcome-name{font-size:20px;color:#fff;margin:0;text-shadow:2px 2px 0 rgba(0,0,0,.3)}.edit-name-btn{background:none;border:2px solid #4a4e69;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:14px;transition:all .2s}.edit-name-btn:hover{border-color:#ffd60a;background:#ffd60a1a}.edit-name-section{margin:16px 0}.edit-name-section .auth-input{margin-bottom:12px}.edit-name-buttons{display:flex;gap:12px;justify-content:center}.welcome-stats{display:flex;justify-content:center;gap:16px;margin-bottom:16px}.stat-box{display:flex;flex-direction:column;align-items:center;background:#4a4e694d;padding:12px 20px;border:2px solid #4a4e69;min-width:70px}.stat-value{font-size:20px;color:#ffd60a;font-weight:700}.stat-label{font-size:7px;color:#9d9dba;margin-top:4px;text-transform:uppercase;letter-spacing:1px}.rarity-breakdown{display:flex;justify-content:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}.rarity-tag{font-size:7px;padding:4px 8px;border-radius:3px;text-transform:uppercase}.rarity-tag.common{background:#9ca3af33;color:#9ca3af}.rarity-tag.rare{background:#60a5fa33;color:#60a5fa}.rarity-tag.epic{background:#a78bfa33;color:#a78bfa}.rarity-tag.legendary{background:#fbbf2433;color:#fbbf24}.welcome-version{margin-top:20px;text-align:center}.marble-count-info{color:#4ade80;font-size:10px;margin-bottom:24px}.auth-buttons{display:flex;flex-direction:column;gap:12px}.pixel-btn.large{padding:16px 24px;font-size:11px}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{color:#6c6c8a;font-size:8px}.version-tag{margin-top:12px;color:#4a4e69;font-size:7px}@media (max-width: 480px){.auth-container{padding:24px 16px}.auth-title{font-size:18px}.auth-option-btn{font-size:9px;padding:12px 16px}}.marble-card{display:flex;flex-direction:column;align-items:center;padding:12px;background:#2d2d44;border:3px solid #4a4e69;transition:all .15s ease;position:relative}.marble-card.rarity-uncommon{border-color:#22c55e}.marble-card.rarity-rare{border-color:#3b82f6}.marble-card.rarity-epic{border-color:#a855f7;box-shadow:0 0 10px #a855f74d}.marble-card.rarity-legendary{border-color:#f59e0b;box-shadow:0 0 15px #f59e0b66;animation:legendaryPulse 2s infinite}@keyframes legendaryPulse{0%,to{box-shadow:0 0 15px #f59e0b66}50%{box-shadow:0 0 25px #f59e0bb3}}.marble-card.clickable{cursor:pointer}.marble-card.clickable:hover{background:#3d3d54;transform:translateY(-2px)}.marble-card.selected{border-color:#ffd60a;box-shadow:0 0 20px #ffd60a4d}.marble-card.size-small{padding:8px}.marble-card.size-large{padding:16px}.rarity-badge{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#000;border:2px solid #1a1a2e}.marble-visual{display:flex;align-items:center;justify-content:center;margin-bottom:8px}.marble-info{text-align:center;width:100%}.marble-name{font-size:8px;color:#fff;margin-bottom:6px;word-break:break-word;line-height:1.3}.size-small .marble-name{font-size:6px}.size-large .marble-name{font-size:10px}.marble-traits{display:flex;gap:4px;justify-content:center;flex-wrap:wrap}.trait{font-size:6px;padding:2px 6px;border-radius:2px;text-transform:uppercase}.trait.weight-heavy{background:#9d0208;color:#fff}.trait.weight-medium{background:#fb8500;color:#000}.trait.weight-light{background:#8ecae6;color:#000}.trait.surface-flat{background:#606c38;color:#fff}.trait.surface-spikey{background:#bc6c25;color:#fff}.trait.material-glass{background:#74b9ff;color:#000}.trait.material-rubber{background:#2d3436;color:#fff}.trait.material-metal{background:#636e72;color:#fff}.breeding-info{display:flex;gap:6px;justify-content:center;margin-top:6px;font-size:6px}.breed-uses{color:#2a9d8f}.breed-cooldown{color:#e63946}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#1a1a2e;border:4px solid #4a4e69;padding:24px;max-width:450px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:10px;right:10px;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:5px 10px}.modal-close:hover{color:#e63946}.modal-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #4a4e69}.marble-title h2{font-size:16px;margin-bottom:8px;color:#fff}.rarity-tag{display:inline-block;padding:4px 12px;font-size:10px;color:#000;font-weight:700}.trait-section,.breeding-section,.rarity-section{margin-bottom:20px}.trait-section h3,.breeding-section h3,.rarity-section h3{font-size:12px;color:#ffd60a;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #4a4e69}.trait-grid{display:flex;flex-direction:column;gap:12px}.trait-item{display:flex;align-items:center;gap:12px;padding:10px;background:#2d2d44;border:2px solid #4a4e69}.trait-icon{font-size:24px;width:40px;text-align:center}.trait-info{display:flex;flex-direction:column;gap:4px}.trait-name{font-size:10px;color:#fff;font-weight:700}.trait-desc{font-size:8px;color:#aaa}.breeding-stats,.rarity-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat{background:#2d2d44;padding:10px;border:2px solid #4a4e69;text-align:center}.stat-label{display:block;font-size:7px;color:#888;margin-bottom:4px;text-transform:uppercase}.stat-value{display:block;font-size:12px;color:#fff}.stat-value.ready{color:#2a9d8f}.stat-value.not-ready{color:#e63946;font-size:8px}.stat-value.cooldown{color:#f4a261}.modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px;padding-top:16px;border-top:2px solid #4a4e69}.modal-actions .pixel-btn{flex:1;max-width:180px}.modal-actions .pixel-btn:disabled{opacity:.5;cursor:not-allowed}.breeding-warning{background:#a855f733;border:2px solid #a855f7;padding:12px;margin-bottom:16px;text-align:center;color:#a855f7;font-size:10px}.no-race-text{font-size:10px;color:#888;text-align:center}.guide-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.guide-modal{background:#1a1a2e;border:4px solid #4a4e69;max-width:500px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.guide-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#2d2d44;border-bottom:3px solid #4a4e69}.guide-header h2{font-size:14px;color:#ffd60a}.close-btn{background:none;border:none;color:#888;font-size:24px;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#fff}.guide-tabs{display:flex;background:#2d2d44;border-bottom:3px solid #4a4e69;overflow-x:auto}.guide-tabs .tab{flex:1;padding:10px 8px;background:none;border:none;color:#888;font-family:"Press Start 2P",monospace;font-size:7px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.guide-tabs .tab:hover{color:#fff;background:#ffffff0d}.guide-tabs .tab.active{color:#ffd60a;background:#1a1a2e;border-bottom:2px solid #ffd60a}.guide-content{flex:1;overflow-y:auto;padding:16px}.guide-section h3{font-size:9px;color:#ccc;margin-bottom:16px;text-align:center}.trait-card{display:flex;gap:12px;padding:12px;background:#2d2d44;border:2px solid #4a4e69;margin-bottom:10px}.trait-badge{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border-radius:4px;flex-shrink:0}.trait-card.heavy .trait-badge{background:#9d0208}.trait-card.medium .trait-badge{background:#fb8500;color:#000}.trait-card.light .trait-badge{background:#8ecae6;color:#000}.trait-card.flat .trait-badge{background:#606c38}.trait-card.spikey .trait-badge{background:#bc6c25}.trait-card.glass .trait-badge{background:#a8dadc;color:#000}.trait-card.rubber .trait-badge{background:#457b9d}.trait-card.metal .trait-badge{background:#6c757d}.trait-info strong{display:block;font-size:10px;color:#fff;margin-bottom:4px}.trait-info p{font-size:8px;color:#aaa;margin-bottom:2px;line-height:1.4}.trait-info .tip{color:#4ade80;font-style:italic;margin-top:4px}.rarity-table{display:flex;flex-direction:column;gap:6px}.rarity-row{display:grid;grid-template-columns:1fr 1fr 1fr;padding:10px 12px;font-size:8px;border-left:4px solid}.rarity-row.common{background:#9ca3af1a;border-color:#9ca3af}.rarity-row.uncommon{background:#22c55e1a;border-color:#22c55e}.rarity-row.rare{background:#3b82f61a;border-color:#3b82f6}.rarity-row.epic{background:#a855f71a;border-color:#a855f7}.rarity-row.legendary{background:#f59e0b1a;border-color:#f59e0b}.rarity-name{color:#fff;font-weight:700}.rarity-speed{color:#4ade80;text-align:center}.rarity-breeds{color:#60a5fa;text-align:right}.guide-note{font-size:8px;color:#fbbf24;text-align:center;margin-top:16px;padding:10px;background:#fbbf241a;border:1px solid #fbbf24}.terrain-list{display:flex;flex-direction:column;gap:8px}.terrain-item{display:flex;gap:12px;padding:10px;background:#2d2d44;border:2px solid #4a4e69}.terrain-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0}.terrain-info strong{display:block;font-size:9px;color:#fff;margin-bottom:4px}.terrain-info p{font-size:8px;color:#aaa;line-height:1.4}.guide-footer{padding:12px;background:#2d2d44;border-top:3px solid #4a4e69;text-align:center}.guide-footer p{font-size:8px;color:#888}@media (max-width: 480px){.guide-modal{max-height:90vh}.guide-tabs .tab{font-size:6px;padding:8px 4px}}.collection-container{min-height:100vh;padding:20px;max-width:1200px;margin:0 auto}.collection-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:4px solid #4a4e69}.collection-header h1{font-size:18px;flex:1}.collection-actions{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.marble-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.selected-info{background:#2d2d44;padding:16px;border:4px solid #ffd60a;margin-bottom:24px;text-align:center}.selected-info p{font-size:10px;color:#ffd60a;margin-bottom:12px}.new-marble-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#2d2d44;padding:24px;border:4px solid #2a9d8f;box-shadow:0 0 40px #2a9d8f80;z-index:100;text-align:center;animation:popIn .3s ease}@keyframes popIn{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.new-marble-popup p{font-size:12px;color:#2a9d8f;margin-bottom:16px}.hint-text{font-size:8px;color:#666;text-align:center;margin-bottom:12px}.empty-collection{text-align:center;padding:40px;color:#888}.empty-collection p{font-size:10px;margin-bottom:12px}.hatched-popup{background:linear-gradient(135deg,#2a9d8f22,#ffd60a22);border:4px solid #ffd60a;padding:20px;margin-bottom:24px;text-align:center;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.hatched-popup h3{font-size:14px;color:#ffd60a;margin-bottom:16px}.hatched-marbles-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.collection-footer{margin-top:32px;padding-top:16px;text-align:center;border-top:2px solid #4a4e69;display:flex;justify-content:center;align-items:center;gap:16px}.collection-footer .version-tag{color:#4a4e69;font-size:8px}.collection-footer .guide-btn{background:none;border:2px solid #4a4e69;color:#888;padding:6px 12px;font-family:"Press Start 2P",monospace;font-size:7px;cursor:pointer;transition:all .2s ease}.collection-footer .guide-btn:hover{border-color:#ffd60a;color:#ffd60a}.breeding-container{min-height:100vh;padding:20px;max-width:900px;margin:0 auto}.breeding-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:4px solid #4a4e69}.breeding-header h1{font-size:18px;flex:1}.breeding-info{background:#2d2d44;padding:16px;border:4px solid #4a4e69;margin-bottom:24px;text-align:center}.breeding-info p{font-size:8px;color:#ccc;margin-bottom:8px}.breeding-info p:last-child{margin-bottom:0}.breeding-chamber{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}.parent-slot,.offspring-slot{background:#2d2d44;border:4px solid #4a4e69;padding:16px;min-width:140px;min-height:160px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.parent-slot:hover{border-color:#6a6e89}.parent-slot.selecting{border-color:#ffd60a;animation:pulse 1s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ffd60a66}50%{box-shadow:0 0 20px 5px #ffd60a66}}.parent-slot.filled{cursor:pointer}.offspring-slot{cursor:default;border-color:#2a9d8f}.empty-slot{text-align:center;color:#666}.empty-slot span{display:block;font-size:10px}.empty-slot .click-hint{font-size:6px;margin-top:8px;color:#888}.empty-slot.offspring span{font-size:32px;color:#2a9d8f}.breeding-plus,.breeding-equals{font-size:32px;color:#ffd60a}.breeding-actions{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.parent-selection{background:#1a1a2e;border:4px solid #4a4e69;padding:20px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-width:90vw;max-height:80vh;overflow-y:auto;z-index:100;box-shadow:0 0 40px #000c}.parent-selection h3{font-size:12px;text-align:center;margin-bottom:16px;color:#ffd60a}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:16px;max-height:400px;overflow-y:auto}.parent-selection>button{display:block;margin:0 auto}.breed-success{background:#2a9d8f33;border:2px solid #2a9d8f;padding:12px;margin-bottom:16px;text-align:center;color:#2a9d8f;font-size:10px;animation:fadeIn .3s ease}.breed-error{background:#e6394633;border:2px solid #e63946;padding:12px;margin-bottom:16px;text-align:center;color:#e63946;font-size:10px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hatched-notification{background:linear-gradient(135deg,#2a9d8f22,#ffd60a22);border:4px solid #ffd60a;padding:20px;margin-bottom:24px;text-align:center;animation:celebrate .5s ease}@keyframes celebrate{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}.hatched-notification h3{font-size:14px;color:#ffd60a;margin-bottom:16px}.hatched-marbles{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.incubator-section{background:#2d2d44;border:4px solid #a855f7;padding:16px;margin-bottom:24px}.incubator-section h2{font-size:12px;color:#a855f7;margin-bottom:8px;text-align:center}.incubator-full-warning{font-size:9px;color:#f59e0b;text-align:center;margin-bottom:12px;padding:8px;background:#f59e0b1a;border:1px solid #f59e0b}.incubator-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.incubating-egg{background:#1a1a2e;border:2px solid #4a4e69;padding:12px;text-align:center;border-radius:8px}.egg-icon{font-size:32px;margin-bottom:8px;animation:wobble 2s ease-in-out infinite}@keyframes wobble{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.egg-name{font-size:8px;color:#ccc;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.egg-timer{font-size:10px;color:#ffd60a;font-weight:700;margin-bottom:8px}.egg-progress-bar{height:6px;background:#1a1a2e;border:1px solid #4a4e69;overflow:hidden}.egg-progress{height:100%;background:linear-gradient(90deg,#a855f7,#f59e0b);transition:width 1s linear}.lobby-container{min-height:100vh;padding:20px;max-width:700px;margin:0 auto}.lobby-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:4px solid #4a4e69}.lobby-header h1{font-size:18px;flex:1}.player-count{font-size:14px;background:#2a9d8f;padding:8px 16px;border:3px solid #1a5f56}.lobby-instruction{font-size:10px;color:#ccc;text-align:center;margin-bottom:20px}.marble-selection{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.no-marbles{text-align:center;padding:40px;color:#888}.no-marbles p{font-size:10px;margin-bottom:8px}.countdown{text-align:center;margin-bottom:24px;background:#2d2d44;padding:20px;border:4px solid #ffd60a}.countdown span{display:block;font-size:10px;color:#ffd60a}.countdown-number{font-size:48px!important;margin-top:12px;animation:pulse 1s infinite}.participants-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.participant{display:flex;align-items:center;gap:12px;background:#2d2d44;padding:12px;border:3px solid #4a4e69}.participant.is-player{border-color:#ffd60a;background:#3d3d54}.participant-number{font-size:16px;color:#888;width:30px;text-align:center}.participant-info{flex:1}.participant-name{display:block;font-size:10px;color:#fff;margin-bottom:4px}.participant .marble-name{display:block;font-size:7px;color:#888}.participant-traits{display:flex;gap:4px}.player-type-tag{font-size:8px;padding:2px 6px;border-radius:3px;font-weight:700;margin-right:8px}.player-type-tag.ai{background:#6366f1;color:#fff}.player-type-tag.real{background:#10b981;color:#fff}.mini-trait{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:2px}.mini-trait.heavy{background:#9d0208}.mini-trait.medium{background:#fb8500;color:#000}.mini-trait.light{background:#8ecae6;color:#000}.mini-trait.flat{background:#606c38}.mini-trait.spikey{background:#bc6c25}.lobby-info{background:#2d2d44;padding:16px;border:4px solid #e63946;margin-bottom:24px;text-align:center}.lobby-info p{font-size:8px;color:#e63946;margin-bottom:8px}.lobby-info p:last-child{margin-bottom:0;color:#ccc}.lobby-container>.pixel-btn{display:block;margin:0 auto}.selected-racer{text-align:center;margin-bottom:24px}.selected-racer p{font-size:10px;color:#888;margin-bottom:12px}.selected-racer .marble-card{display:inline-block}.mode-selection{display:flex;gap:16px;margin-bottom:24px}.mode-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background:#2d2d44;border:4px solid #4a4e69;cursor:pointer;transition:all .2s ease;font-family:"Press Start 2P",monospace}.mode-btn:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 6px #0000004d}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.mode-btn.ai-mode{border-color:#4ade80}.mode-btn.ai-mode:hover:not(:disabled){background:#2d3d34;border-color:#5eeb92}.mode-btn.multiplayer-mode{border-color:#60a5fa}.mode-btn.multiplayer-mode:hover:not(:disabled){background:#2d3444;border-color:#93c5fd}.mode-icon{font-size:32px}.mode-title{font-size:12px;color:#fff}.mode-desc{font-size:8px;color:#9d9dba}.mode-note{font-size:7px;color:#4ade80;background:#4ade801a;padding:4px 8px;border-radius:4px}.mode-btn.multiplayer-mode .mode-note{color:#60a5fa;background:#60a5fa1a}.searching-animation{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.searching-spinner{width:60px;height:60px;border:6px solid #4a4e69;border-top-color:#60a5fa;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}.searching-animation p{font-size:12px;color:#9d9dba}.lobby-container.multiplayer{border:3px solid #60a5fa;background:linear-gradient(180deg,#1a1a2e,#16213e)}.multiplayer-badge{display:inline-block;font-size:8px;background:#ef4444;color:#fff;padding:4px 8px;border-radius:4px;margin-right:12px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.participant.is-host{border-color:#fbbf24}.participant.empty{border-style:dashed;opacity:.6}.empty-slot-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#4a4e69;border-radius:50%;font-size:16px;color:#888}.waiting-text{font-size:9px;color:#888;font-style:italic}.multiplayer-info{border-color:#60a5fa}.multiplayer-info p{color:#60a5fa}.multiplayer-info p:last-child{color:#e63946}.waiting-for-host{text-align:center;padding:20px;background:#2d2d44;border:3px solid #4a4e69}.waiting-for-host p{font-size:10px;color:#9d9dba}.multiplayer-error{background:#ef44441a;border:3px solid #ef4444;color:#ef4444;padding:12px;font-size:9px;text-align:center;margin-bottom:16px}.waiting-timer{text-align:center;padding:16px;background:#fbbf241a;border:3px solid #fbbf24;margin-bottom:16px}.waiting-timer p{font-size:10px;color:#fbbf24;margin-bottom:12px}.waiting-timer .timer-value{font-size:14px;font-weight:700;color:#fff}.waiting-timer .pixel-btn.secondary{background:#4a4e69;border-color:#6c6c8a;font-size:8px;padding:8px 16px}.waiting-timer .pixel-btn.secondary:hover{background:#5a5e79}.matchmaking-timer{display:flex;flex-direction:column;align-items:center;padding:20px;margin-bottom:20px}.timer-circle{position:relative;width:120px;height:120px;margin-bottom:16px}.timer-circle svg{width:100%;height:100%;transform:scaleX(-1)}.timer-circle .timer-progress{transition:stroke-dasharray 1s linear}.timer-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;color:#fbbf24;font-family:"Press Start 2P",monospace}.timer-label{font-size:12px;color:#fff;margin-bottom:8px}.timer-subtext{font-size:8px;color:#888}.lobby-actions{display:flex;justify-content:center;margin-bottom:16px}.lobby-actions .pixel-btn.secondary{background:#4a4e69;border-color:#6c6c8a;font-size:9px;padding:12px 20px}.lobby-actions .pixel-btn.secondary:hover:not(:disabled){background:#5a5e79}.lobby-actions .pixel-btn.secondary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.mode-selection{flex-direction:column}.timer-circle{width:100px;height:100px}.timer-text{font-size:20px}}.race-viewer{display:flex;flex-direction:column;align-items:center;padding:20px;min-height:100vh;position:relative}.race-canvas{border:4px solid #4a4e69;box-shadow:8px 8px #0000004d;image-rendering:pixelated;max-width:100%;height:auto}.race-controls{display:flex;align-items:center;gap:16px;margin-top:20px;background:#2d2d44;padding:16px;border:4px solid #4a4e69}.frame-slider{width:300px;height:8px;-webkit-appearance:none;background:#1a1a2e;border:2px solid #4a4e69;cursor:pointer}.frame-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#ffd60a;border:3px solid #b89a00;cursor:pointer}.frame-slider::-moz-range-thumb{width:20px;height:20px;background:#ffd60a;border:3px solid #b89a00;cursor:pointer}.speed-label{font-size:10px;color:#ccc;min-width:50px}.race-complete-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#2d2d44;padding:32px;border:4px solid #ffd60a;box-shadow:0 0 60px #ffd60a4d;z-index:100;text-align:center;min-width:300px}.race-complete-overlay h2{font-size:16px;color:#ffd60a;margin-bottom:24px}.placements{margin-bottom:24px}.placement{display:flex;align-items:center;gap:12px;padding:8px 16px;margin-bottom:4px;background:#1a1a2e}.placement.is-player{background:#3d3d54;border:2px solid #ffd60a}.placement .place{font-size:14px;color:#ffd60a;min-width:40px}.placement:first-child .place{color:gold}.placement:nth-child(2) .place{color:silver}.placement:nth-child(3) .place{color:#cd7f32}.placement .name{font-size:8px;color:#fff;flex:1;text-align:left}.placement .you{font-size:7px;color:#ffd60a}.countdown-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0006;z-index:50;pointer-events:none}.countdown-number{font-size:120px;font-family:"Press Start 2P",monospace;color:#ffd60a;text-shadow:0 0 20px rgba(255,214,10,.8),0 0 40px rgba(255,214,10,.6),0 0 60px rgba(255,214,10,.4),6px 6px 0 #b89a00;transition:transform .1s ease-out;animation:countdown-pulse .8s ease-in-out infinite}.countdown-number.go{color:#4ade80;text-shadow:0 0 20px rgba(74,222,128,.8),0 0 40px rgba(74,222,128,.6),0 0 60px rgba(74,222,128,.4),6px 6px 0 #22c55e;animation:countdown-go .4s ease-out}@keyframes countdown-pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes countdown-go{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:1}to{transform:scale(2);opacity:0}}.confetti-canvas{position:absolute;top:20px;left:50%;transform:translate(-50%);pointer-events:none;z-index:60}.marble-tooltip{position:fixed;background:#2d2d44;border:3px solid #4a4e69;box-shadow:4px 4px #0006;padding:12px;z-index:200;pointer-events:none;min-width:160px}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid #4a4e69}.tooltip-name{font-family:"Press Start 2P",monospace;font-size:9px;color:#fff}.tooltip-rarity{font-family:"Press Start 2P",monospace;font-size:7px;font-weight:700}.tooltip-stats{display:flex;flex-direction:column;gap:6px}.tooltip-stat{display:flex;justify-content:space-between;font-family:"Press Start 2P",monospace;font-size:7px}.stat-label{color:#888}.stat-value{color:#fff;text-transform:capitalize}.results-container{min-height:100vh;padding:20px;max-width:700px;margin:0 auto}.results-banner{text-align:center;padding:32px;margin-bottom:24px;border:4px solid}.results-banner.winner{background:linear-gradient(180deg,#2a9d8f22,#2a9d8f44);border-color:#2a9d8f}.results-banner.loser{background:linear-gradient(180deg,#e6394622,#e6394644);border-color:#e63946}.results-banner h1{font-size:24px;margin-bottom:12px}.results-banner.winner h1{color:#ffd60a;text-shadow:2px 2px 0 #b89a00}.results-banner.loser h1{color:#e63946;text-shadow:2px 2px 0 #9d0208}.results-banner p{font-size:10px;color:#ccc}.final-standings{background:#2d2d44;padding:20px;border:4px solid #4a4e69;margin-bottom:24px}.final-standings h2{font-size:12px;color:#ffd60a;text-align:center;margin-bottom:16px}.standings-list{display:flex;flex-direction:column;gap:8px}.standing{display:flex;align-items:center;gap:12px;padding:12px;background:#1a1a2e;border:2px solid transparent}.standing.is-player{border-color:#ffd60a;background:#3d3d54}.standing.winner{background:linear-gradient(90deg,#ffd60a22 0%,transparent 100%)}.standing-place{font-size:16px;min-width:40px;text-align:center}.standing-info{flex:1;display:flex;flex-direction:column;gap:4px}.standing-name{font-size:8px;color:#fff}.standing-time{font-size:7px;color:#888}.you-badge{font-size:8px;background:#ffd60a;color:#000;padding:4px 8px}.marbles-won,.marbles-lost{padding:20px;border:4px solid;margin-bottom:24px;text-align:center}.marbles-won{background:#2a9d8f22;border-color:#2a9d8f}.marbles-lost{background:#e6394622;border-color:#e63946}.marbles-won h2,.marbles-lost h2{font-size:12px;margin-bottom:12px}.marbles-won h2{color:#2a9d8f}.marbles-lost h2{color:#e63946}.marbles-won p,.marbles-lost p{font-size:8px;color:#ccc;margin-bottom:16px}.won-grid,.lost-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.results-stats{text-align:center;margin-bottom:24px}.results-stats h3{font-size:10px;color:#888;margin-bottom:8px}.marble-count{font-size:12px}.marble-count strong{color:#ffd60a;font-size:20px}.results-actions{display:flex;gap:16px;justify-content:center}.leaderboard-container{min-height:100vh;padding:20px;max-width:700px;margin:0 auto}.leaderboard-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:4px solid #4a4e69}.leaderboard-header h1{font-size:18px;flex:1}.player-stats-card{background:linear-gradient(135deg,#2d2d44,#1a1a2e);border:4px solid #ffd60a;padding:20px;margin-bottom:24px}.player-stats-card h2{font-size:12px;color:#ffd60a;margin-bottom:16px;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-item{text-align:center;padding:12px 8px;background:#ffffff0d;border:2px solid #4a4e69}.stat-item.highlight{border-color:#4ade80;background:#4ade801a}.stat-value{display:block;font-size:18px;color:#fff;margin-bottom:4px}.stat-item.highlight .stat-value{color:#4ade80}.stat-label{display:block;font-size:7px;color:#888;text-transform:uppercase}.stats-note{font-size:8px;color:#fbbf24;text-align:center;margin-top:16px}.sync-section{margin-top:16px;text-align:center}.sync-btn{margin-top:12px;background:#2563eb!important;border-color:#1d4ed8!important}.sync-btn:hover:not(:disabled){background:#3b82f6!important}.sync-btn:disabled{opacity:.6;cursor:wait}.sync-success{font-size:9px;color:#4ade80;text-align:center;margin-top:12px}.leaderboard-content{margin-bottom:24px}.leaderboard-notice,.leaderboard-empty{text-align:center;padding:40px 20px;background:#2d2d44;border:3px solid #4a4e69}.leaderboard-notice p,.leaderboard-empty p{font-size:10px;color:#888;margin-bottom:8px}.leaderboard-notice p:last-child,.leaderboard-empty p:last-child{margin-bottom:0}.leaderboard-loading{display:flex;flex-direction:column;align-items:center;padding:40px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #4a4e69;border-top-color:#ffd60a;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.leaderboard-loading p{font-size:10px;color:#888}.leaderboard-error{text-align:center;padding:20px;background:#ef44441a;border:3px solid #ef4444}.leaderboard-error p{font-size:10px;color:#ef4444}.leaderboard-table{background:#2d2d44;border:3px solid #4a4e69;overflow:hidden}.table-header{display:grid;grid-template-columns:60px 1fr 60px 60px 70px;padding:12px 16px;background:#1a1a2e;border-bottom:3px solid #4a4e69;font-size:8px;color:#888;text-transform:uppercase}.table-body{max-height:400px;overflow-y:auto}.table-row{display:grid;grid-template-columns:60px 1fr 60px 60px 70px;padding:12px 16px;border-bottom:1px solid #3d3d54;font-size:9px;align-items:center;transition:background .2s ease}.table-row:last-child{border-bottom:none}.table-row:hover{background:#ffffff0d}.table-row.is-player{background:#ffd60a1a;border-color:#ffd60a}.table-row.rank-1{background:#ffd70026}.table-row.rank-2{background:#c0c0c01a}.table-row.rank-3{background:#cd7f321a}.table-row.unsynced{background:#fbbf241a;border:1px dashed #fbbf24;opacity:.8}.col-rank{font-size:12px;text-align:center}.col-name{color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-wins{text-align:center;color:#4ade80}.col-races{text-align:center;color:#888}.col-ratio{text-align:center;color:#fbbf24;font-weight:700}.leaderboard-info{text-align:center}.leaderboard-info p{font-size:8px;color:#666}@media (max-width: 480px){.stats-grid{grid-template-columns:repeat(2,1fr)}.table-header,.table-row{grid-template-columns:50px 1fr 50px 50px 60px;padding:10px 12px;font-size:8px}.col-rank{font-size:10px}}.app{min-height:100vh;position:relative}.player-info{position:fixed;top:16px;right:16px;display:flex;align-items:center;gap:12px;background:#2d2d44;padding:8px 16px;border:3px solid #4a4e69;z-index:50;font-size:8px}.player-name{color:#ffd60a}.marble-count{color:#fff}.reward-indicator{animation:bounce .5s infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-3px)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:"Press Start 2P",cursive;background:linear-gradient(180deg,#1a1a2e,#16213e);color:#eee;min-height:100vh;image-rendering:pixelated;-webkit-font-smoothing:none}#root{min-height:100vh}.pixel-btn{font-family:"Press Start 2P",cursive;font-size:10px;padding:12px 24px;background:#4a4e69;color:#fff;border:4px solid #22223b;cursor:pointer;transition:all .1s;text-transform:uppercase;box-shadow:4px 4px #22223b}.pixel-btn:hover{background:#6a6e89;transform:translate(-2px,-2px);box-shadow:6px 6px #22223b}.pixel-btn:active{transform:translate(2px,2px);box-shadow:2px 2px #22223b}.pixel-btn.primary{background:#e63946;border-color:#9d0208;box-shadow:4px 4px #9d0208}.pixel-btn.primary:hover{background:#ff6b6b}.pixel-btn.success{background:#2a9d8f;border-color:#1a5f56;box-shadow:4px 4px #1a5f56}.pixel-btn.success:hover{background:#3ac9b8}.pixel-panel{background:#2d2d44;border:4px solid #4a4e69;box-shadow:8px 8px #0000004d;padding:20px}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#1a1a2e}::-webkit-scrollbar-thumb{background:#4a4e69;border:2px solid #1a1a2e}::-webkit-scrollbar-thumb:hover{background:#6a6e89}
