*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Segoe UI,-apple-system,sans-serif;background-color:#121212;color:#e0e0e0;display:flex;justify-content:center;align-items:center;min-height:100vh;margin:0;padding:20px}.container{display:flex;flex-direction:column;align-items:center;gap:30px;background:#1a1a1a;padding:48px;border-radius:16px;border:1px solid rgba(255,255,255,.06);box-shadow:0 24px 64px #00000080;max-width:600px;width:100%}.lobby-content{width:100%;padding:0}.lobby-header{text-align:center;margin-bottom:36px}.lobby-header h1{margin:0;font-size:44px;color:#f5f5f5;letter-spacing:3px;font-weight:700}.lobby-header .subtitle{margin:14px 0 0;font-size:14px;color:#777;font-weight:400;letter-spacing:1px;text-transform:uppercase}.lobby-form{display:flex;flex-direction:column;gap:24px}.form-section{padding:28px;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.06);transition:all .3s ease}.form-section:hover{border-color:#c9a96e4d;background:#ffffff08}.form-section h2{margin:0 0 8px;font-size:16px;color:#e0e0e0;font-weight:600}.section-desc{margin:0 0 20px;font-size:13px;color:#666;line-height:1.5}.input-group{display:flex;gap:10px;flex-wrap:wrap}.lobby-input{flex:1;min-width:150px;padding:12px 16px;font-size:14px;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-family:inherit;transition:all .25s ease;background:#ffffff0a;color:#e0e0e0}.lobby-input:focus{outline:none;border-color:#c9a96e;box-shadow:0 0 0 3px #c9a96e1a;background:#ffffff0f}.lobby-input::placeholder{color:#555}.divider{text-align:center;position:relative;color:#555;font-size:13px;font-weight:500}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.08),transparent)}.divider span{position:relative;background:#1a1a1a;padding:0 15px;text-transform:uppercase;letter-spacing:1px}button{padding:11px 22px;font-size:13px;cursor:pointer;border:1px solid rgba(255,255,255,.1);border-radius:8px;background-color:#ffffff0d;color:#e0e0e0;font-weight:600;transition:all .25s ease;letter-spacing:.3px;font-family:inherit}button:hover{background-color:#c9a96e26;border-color:#c9a96e;color:#c9a96e}button:active{transform:scale(.98)}.btn-primary,.btn-secondary{padding:12px 24px;font-size:13px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:1px}.btn-primary{background:#c9a96e;color:#121212}.btn-primary:hover{background:#d4b87a;box-shadow:0 4px 16px #c9a96e4d;color:#121212;border-color:transparent}.btn-primary:active{transform:scale(.98)}.btn-secondary{width:100%;background:transparent;color:#c9a96e;font-size:14px;padding:14px 28px;border:1px solid #c9a96e}.btn-secondary:hover{background:#c9a96e1a;box-shadow:0 4px 16px #c9a96e26;color:#c9a96e;border-color:#c9a96e}.btn-secondary:active{transform:scale(.98)}.btn-back{padding:10px 20px;font-size:13px;background:transparent;color:#888;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .25s ease;font-weight:500;letter-spacing:.3px}.btn-back:hover{color:#ccc;border-color:#ffffff26;background:#ffffff08}.btn-icon{padding:8px 16px;font-size:12px;background:#c9a96e1a;color:#c9a96e;border:1px solid rgba(201,169,110,.3);border-radius:6px;cursor:pointer;transition:all .25s ease;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.btn-icon:hover{background:#c9a96e33;border-color:#c9a96e}.setup-form{display:flex;flex-direction:column;gap:24px}.option-group{display:flex;gap:10px}.option-btn{flex:1;padding:14px 16px;font-size:14px;font-weight:600;background:#ffffff0a;color:#999;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .25s ease;text-align:center}.option-btn:hover{background:#ffffff0f;border-color:#ffffff26;color:#ccc}.option-btn.selected{background:#c9a96e26;border-color:#c9a96e;color:#c9a96e;box-shadow:0 0 0 1px #c9a96e33}.setup-actions{display:flex;gap:12px;justify-content:space-between;align-items:center;margin-top:8px}.waiting-content{display:flex;flex-direction:column;align-items:center;gap:28px}.room-id-display{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;width:100%;justify-content:center}.room-id-display code{font-family:SF Mono,Fira Code,monospace;font-size:20px;color:#c9a96e;letter-spacing:2px;font-weight:600}.waiting-info{display:flex;flex-direction:column;align-items:center;gap:16px}.waiting-info p{color:#777;font-size:14px}.waiting-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.06);border-top-color:#c9a96e;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#app{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.game-layout{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.player-bar{display:flex;align-items:center;justify-content:space-between;width:440px;padding:6px 4px}.player-info{display:flex;align-items:center;gap:8px}.player-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.player-color-dot.white{background:#e8e8e8;box-shadow:0 0 0 1px #fff3}.player-color-dot.black{background:#555;box-shadow:0 0 0 1px #ffffff1a}.player-label{font-size:13px;font-weight:500;color:#777;transition:color .3s ease}.player-bar.active-turn .player-label{color:#ccc}.timer{font-family:SF Mono,Fira Code,monospace;font-size:15px;font-weight:700;color:#777;letter-spacing:1px;min-width:56px;text-align:center;padding:5px 10px;border-radius:6px;background:#ffffff0d;transition:all .3s ease}.timer.active{color:#fff;background:#ffffff1f}.timer.low-time{color:#c0504a;background:#c0504a1a}.timer.active.low-time{color:#e05555;background:#e0555526}.game-status-banner{display:none;width:440px;padding:14px 20px;background:#c9a96e14;border:1px solid rgba(201,169,110,.2);border-radius:10px;text-align:center}.game-status-banner.visible{display:block}#game-status{font-weight:700;font-size:15px;color:#c9a96e;letter-spacing:.3px}.game-meta{display:flex;align-items:center;justify-content:center;gap:10px;width:440px}.game-meta button{padding:11px 28px}#chess-board{width:440px;height:440px;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);border:2px solid rgba(255,255,255,.08);border-radius:4px;gap:0;box-shadow:0 16px 48px #0006,inset 0 0 0 1px #ffffff08;overflow:hidden}.square{width:55px;height:55px;display:flex;justify-content:center;align-items:center;cursor:pointer;position:relative;transition:background-color .15s ease}.square.light{background-color:#b8b09a}.square.dark{background-color:#6b6352}.square.highlight{background-color:#c9a96e99;box-shadow:inset 0 0 12px #00000040}.square.valid-move:after{content:"";width:13px;height:13px;background-color:#00000059;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10}.square.valid-move:hover:after{background-color:#c9a96eb3}.square.last-move{background-color:#c9a96e73!important}.square.drag-source .piece{opacity:.3}.square.in-check{background-color:#8b3a3a!important;box-shadow:inset 0 0 14px #b4323280}.piece{width:5em;height:5em;object-fit:contain;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:5;max-width:100%;max-height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.promotion-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.promotion-container{background-color:#1e1e1e;border-radius:14px;padding:30px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px #00000080;text-align:center}.promotion-container h2{margin-top:0;margin-bottom:20px;color:#e0e0e0;font-size:18px;font-weight:600}.promotion-options{display:flex;gap:12px;justify-content:center}.promotion-btn{padding:8px;border:1px solid rgba(255,255,255,.1);background-color:#2a2a2a;border-radius:10px;cursor:pointer;transition:all .2s;width:72px;height:72px;display:flex;align-items:center;justify-content:center}.promotion-btn img{width:52px;height:52px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.promotion-btn:hover{background-color:#c9a96e33;border-color:#c9a96e;transform:scale(1.08)}.promotion-btn:active{transform:scale(.96)}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-tabs{display:flex;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.06);overflow:hidden}.auth-tab{flex:1;padding:12px;font-size:14px;font-weight:600;background:transparent;color:#777;border:none;border-radius:0;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px}.auth-tab:hover{color:#ccc;background:#ffffff08}.auth-tab.active{color:#c9a96e;background:#c9a96e1a}.auth-panel .form-section{margin:0}.auth-fields{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.auth-error{color:#e05555;font-size:13px;min-height:18px;margin-bottom:8px}.auth-submit{width:100%;padding:14px;font-size:14px}.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 24px;font-size:14px;font-weight:600;background:#ffffff0d;color:#e0e0e0;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .25s ease;font-family:inherit}.btn-google:hover{background:#ffffff14;border-color:#fff3}.btn-google svg{flex-shrink:0}.user-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 0 20px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:-10px}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;background:#c9a96e26;border:1px solid rgba(201,169,110,.3)}.user-avatar[src=""],.user-avatar:not([src]){display:none}.user-name{font-size:14px;font-weight:600;color:#e0e0e0}.btn-sm{padding:6px 14px;font-size:12px}@media(max-width:520px){.container{padding:24px}#chess-board{width:320px;height:320px}.square{width:40px;height:40px}.player-bar{width:320px}.lobby-header h1{font-size:32px}}
