*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;background-color:#fff;color:#121212;line-height:1.5;min-height:100vh;min-height:100dvh}h1,h2,h3{font-family:nyt-cheltenham,Georgia,Times New Roman,serif;font-weight:700;letter-spacing:-.01em}.container{width:100%;max-width:600px;margin:0 auto;padding:0 1.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:.75rem 1rem;border:1px solid #121212;border-radius:2rem;background:#fff;color:#121212;cursor:pointer;font-size:.9375rem;font-weight:600;font-family:inherit;transition:background-color .15s,color .15s;-webkit-user-select:none;user-select:none}.btn:hover{background:#121212;color:#fff}.btn:active{transform:scale(.98)}.btn-primary{background:#121212;color:#fff;border-color:#121212}.btn-primary:hover{background:#333;border-color:#333}.btn-primary:disabled{background:#ccc;border-color:#ccc;cursor:not-allowed}.btn-secondary{background:#fff;color:#121212;border-color:#ddd}.btn-secondary:hover{background:#f5f5f5;border-color:#999;color:#121212}.btn-danger{background:#fff;color:#c62828;border-color:#c62828}.btn-danger:hover{background:#c62828;color:#fff}.btn-full{width:100%}.btn-small{min-height:36px;padding:.5rem 1rem;font-size:.875rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:#666}.form-group input{width:100%;min-height:48px;padding:12px 16px;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus{outline:none;border-color:#121212}.error{color:#c62828;font-size:.875rem;margin-top:.5rem}.card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem}.auth-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:1.5rem;background:#f7f7f7}.auth-card{width:100%;max-width:400px;margin:0 auto;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem}.auth-card h1{margin-bottom:2rem;text-align:center;font-size:1.75rem}.auth-card .form-footer{margin-top:1.5rem;text-align:center;font-size:.9375rem;color:#666}.auth-card .form-footer a{color:#121212;font-weight:600;text-decoration:underline}.header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:100}.header-logo{font-family:nyt-cheltenham,Georgia,Times New Roman,serif;font-size:1.375rem;font-weight:700;color:#121212;text-decoration:none;letter-spacing:-.02em}.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;background:none;border:none;cursor:pointer;z-index:200}.hamburger span{display:block;width:24px;height:2px;background:#121212;border-radius:1px;transition:transform .3s,opacity .3s}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-menu{position:fixed;top:0;right:0;width:300px;max-width:85vw;height:100vh;height:100dvh;background:#fff;padding:5rem 0 2rem;transform:translate(100%);transition:transform .3s ease;z-index:150;border-left:1px solid #e0e0e0;display:flex;flex-direction:column}.nav-menu.open{transform:translate(0)}.nav-link{display:flex;align-items:center;min-height:52px;padding:0 1.5rem;font-size:1rem;font-weight:500;color:#121212;text-decoration:none;border:none;background:none;width:100%;text-align:left;cursor:pointer;transition:background-color .15s}.nav-link:hover,.nav-link:active{background-color:#f7f7f7}.nav-link.active{font-weight:700}.nav-logout{margin-top:auto;color:#c62828;border-top:1px solid #e0e0e0}.nav-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:140}.page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:#fff}.page-title{font-size:2rem;margin-bottom:.5rem;padding-top:1.5rem}.page-header{display:flex;align-items:center;justify-content:space-between;padding-top:1.5rem;margin-bottom:1.5rem}.page-header .page-title{padding-top:0;margin-bottom:0}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;font-size:1rem;color:#666}.loading-text{text-align:center;color:#666;padding:3rem 0}.main-content{padding-bottom:2rem;flex:1}.text-center{text-align:center}.text-muted{color:#666}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.alert{padding:1rem;border-radius:4px;margin-bottom:1rem;font-size:.9375rem}.alert-error{background-color:#fff5f5;color:#c62828;border:1px solid #ffcdd2}.alert-success{background-color:#f1f8e9;color:#2e7d32;border:1px solid #c5e1a5}.games-hub{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.game-hub-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;width:100%;font-family:inherit}.game-hub-card:hover{border-color:#121212;box-shadow:0 2px 8px #00000014}.game-hub-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f7f7f7;border-radius:8px;flex-shrink:0}.game-hub-icon svg{width:28px;height:28px;color:#121212}.game-hub-info{flex:1}.game-hub-title{font-family:nyt-cheltenham,Georgia,Times New Roman,serif;font-size:1.25rem;font-weight:700;margin:0}.game-hub-description{font-size:.875rem;color:#666;margin:.125rem 0 0}.game-hub-badge{background:#121212;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .625rem;border-radius:1rem;min-width:1.5rem;text-align:center}.game-hub-arrow{color:#999;flex-shrink:0}.game-hub-arrow svg{width:20px;height:20px}.section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#666;margin-bottom:.75rem;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}.game-section{margin-bottom:2rem}.game-list{list-style:none;padding:0;margin:0}.game-card{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .15s;margin:0 -.5rem;padding:1rem .5rem;border-radius:4px}.game-card:hover{background-color:#f7f7f7}.game-card:last-child{border-bottom:none}.game-card-main{display:flex;flex-direction:column;gap:.125rem}.game-card-opponent{font-weight:600;font-size:1rem}.game-card-score{font-size:.875rem;color:#666}.status-badge{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.status-badge.your-turn{background:#121212;color:#fff}.status-badge.waiting{background:#f7f7f7;color:#666}.status-badge.won{background:#e8f5e9;color:#2e7d32}.status-badge.lost{background:#ffebee;color:#c62828}.status-badge.draw{background:#f7f7f7;color:#666}.empty-state{text-align:center;padding:3rem 1rem;color:#666}.empty-state p{margin-bottom:.5rem}.profile-info{display:flex;flex-direction:column;gap:1.25rem}.profile-row{display:flex;flex-direction:column;gap:.25rem}.profile-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#666}.profile-value{font-size:1.125rem;font-weight:500}.friend-code-display{display:flex;align-items:center;gap:1rem}.friend-code{font-size:1.375rem;font-weight:700;letter-spacing:.15em;font-family:SF Mono,Monaco,Inconsolata,monospace;background:#f7f7f7;padding:.875rem 1.25rem;border-radius:8px;border:1px solid #e0e0e0;flex:1;text-align:center}.add-friend-form{display:flex;gap:.75rem}.friend-code-input{flex:1;min-height:44px;padding:10px 14px;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.friend-code-input:focus{outline:none;border-color:#121212}.friend-list{list-style:none;padding:0;margin:0}.friend-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid #e0e0e0}.friend-item:last-child{border-bottom:none}.friend-name{font-weight:600;font-size:1rem}.friend-actions{display:flex;gap:.5rem}.section-title{font-size:1.125rem;margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:200}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:8px;padding:1.5rem;width:calc(100% - 2rem);max-width:400px;z-index:210;max-height:85vh;overflow-y:auto}.modal-title{font-size:1.5rem;margin-bottom:.5rem}.modal-subtitle{color:#666;margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.friend-select-list{list-style:none;padding:0;margin:0}.friend-select-btn{width:100%;padding:1rem;border:1px solid #e0e0e0;border-radius:4px;background:#fff;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;margin-bottom:.5rem;text-align:left;transition:border-color .15s,background-color .15s}.friend-select-btn:hover{background-color:#f7f7f7;border-color:#121212}.friend-select-btn:disabled{opacity:.5;cursor:not-allowed}.scrabble-page{background:linear-gradient(180deg,#d4a574,#c49264,#b8845a);min-height:100vh;min-height:100dvh}.scrabble-page .header{flex-shrink:0;background:#8b5a2bf2;border-bottom:1px solid rgba(101,67,33,.6)}.scrabble-page .header-logo{color:#f5e6d3}.scrabble-page .hamburger span{background:#f5e6d3}.scrabble-container{padding:.375rem;display:flex;flex-direction:column;height:calc(100vh - 53px);height:calc(100dvh - 53px);overflow:hidden}.scrabble-board-container{flex:1;min-height:0;display:flex;justify-content:center;align-items:center;margin-bottom:.375rem;overflow:auto;-webkit-overflow-scrolling:touch}.scrabble-board-wrapper{display:inline-block;border-radius:6px;background:#8b5a2b;box-shadow:0 2px 8px #0000004d}.scrabble-board{display:flex;flex-direction:column;gap:2px;padding:3px;cursor:pointer}.scrabble-row{display:flex;gap:2px}.scrabble-cell{width:36px;height:36px;border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative;transition:all .1s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.scrabble-cell.clickable{cursor:pointer}@media (hover: hover){.scrabble-cell.clickable:hover{filter:brightness(1.1)}}.scrabble-cell.normal{background:#d4c4a8;border:1px solid #c4b498}.scrabble-cell.double-letter{background:#7cb3c4;border:1px solid #5a9aad}.scrabble-cell.triple-letter{background:#5a8fa4;border:1px solid #4a7f94}.scrabble-cell.double-word{background:#e8a87c;border:1px solid #d89868}.scrabble-cell.triple-word{background:#c65d3d;border:1px solid #b64d2d}.scrabble-cell.center{background:#e8a87c;border:1px solid #d89868}.bonus-label{font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;color:#00000080}.scrabble-cell.triple-word .bonus-label,.scrabble-cell.triple-letter .bonus-label{color:#ffffffe6}.scrabble-tile{position:absolute;top:1px;left:1px;right:1px;bottom:1px;background:linear-gradient(135deg,#f5e6d3,#e8d4bc);border-radius:3px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003,inset 0 1px #fff6;font-family:Georgia,Times New Roman,serif}.scrabble-tile.new-tile{background:linear-gradient(135deg,#c8e6c9,#a5d6a7);box-shadow:0 2px 4px #00000040,inset 0 1px #ffffff80,0 0 8px #4caf5066}.scrabble-tile.last-move-tile{background:linear-gradient(135deg,#c8e6c9,#a5d6a7)}.scrabble-tile.connected-top{border-top-left-radius:0;border-top-right-radius:0;top:0}.scrabble-tile.connected-bottom{border-bottom-left-radius:0;border-bottom-right-radius:0;bottom:0}.scrabble-tile.connected-left{border-top-left-radius:0;border-bottom-left-radius:0;left:0}.scrabble-tile.connected-right{border-top-right-radius:0;border-bottom-right-radius:0;right:0}.scrabble-tile .tile-letter{font-size:1.125rem;font-weight:700;color:#4a3728;line-height:1}.scrabble-tile .tile-points{position:absolute;bottom:2px;right:3px;font-size:.5625rem;font-weight:700;color:#6d5344;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif}.blank-underline{position:absolute;bottom:4px;left:6px;right:6px;height:1px;background:#4a3728}.scrabble-rack{display:flex;justify-content:center;gap:.25rem;padding:.5rem .75rem;background:linear-gradient(180deg,#6d4c2a,#5a3d20,#4a3218);border-radius:6px;margin-bottom:.375rem;flex-wrap:wrap;flex-shrink:0;box-shadow:inset 0 2px 4px #0000004d,0 2px 4px #0003;border:2px solid #3d2814}.rack-tile{width:40px;height:44px;border:none;border-radius:4px;background:linear-gradient(135deg,#f5e6d3,#e8d4bc);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:transform .1s,box-shadow .1s;box-shadow:0 3px 6px #0000004d,inset 0 1px #fff6;font-family:Georgia,Times New Roman,serif}.rack-tile:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 12px #00000059,inset 0 1px #fff6}.rack-tile.selected{background:linear-gradient(135deg,#c8e6c9,#a5d6a7);transform:translateY(-5px);box-shadow:0 8px 16px #00000059,0 0 12px #4caf5080,inset 0 1px #ffffff80}.rack-tile:disabled{opacity:.6;cursor:not-allowed}.rack-tile .tile-letter{font-size:1.375rem;font-weight:700;color:#4a3728}.rack-tile .tile-value{font-size:.5rem;font-weight:700;color:#6d5344;position:absolute;bottom:3px;right:4px;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif}.rack-tile .blank-indicator{font-size:1.25rem;font-weight:700;color:#8b7355}.scrabble-actions{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#8b5a2bd9;border:1px solid rgba(101,67,33,.5);border-radius:6px;flex-shrink:0}.actions-left{display:flex;gap:.375rem;align-items:center}.actions-scores{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600}.actions-scores .score-you{color:#f5e6d3;padding:.125rem .375rem;border-radius:3px}.actions-scores .score-you.active{background:#ffd54f40;color:#ffd54f}.actions-scores .score-bag{color:#f5e6d380;font-size:.8125rem;padding:0 .25rem}.actions-scores .score-them{color:#f5e6d3b3;padding:.125rem .375rem;border-radius:3px}.actions-scores .score-them.active{background:#ffd54f26;color:#ffd54fcc}.scrabble-actions .btn-icon{min-width:40px;width:40px;min-height:40px;padding:0;font-size:1.125rem;border-radius:6px}.scrabble-actions .btn-secondary{background:#f5e6d326;border-color:#f5e6d34d;color:#f5e6d3}.scrabble-actions .btn-secondary:hover{background:#f5e6d340;border-color:#f5e6d380;color:#f5e6d3}.scrabble-actions .btn-play{min-width:90px;min-height:40px;padding:.5rem 1rem;font-size:.875rem;font-weight:700;border-radius:6px;text-transform:uppercase;letter-spacing:.03em}.scrabble-actions .btn-play.btn-primary{background:linear-gradient(180deg,#8bc34a,#689f38);border:none;color:#fff}.scrabble-actions .btn-play.btn-primary:hover{background:linear-gradient(180deg,#9ccc65,#7cb342)}.scrabble-actions .btn-play.btn-disabled{background:#f5e6d326;border:1px solid rgba(245,230,211,.2);color:#f5e6d380}.scrabble-page .dropup-container{position:relative}.scrabble-page .dropup-menu{position:absolute;bottom:calc(100% + 8px);left:0;min-width:140px;background:#f5e6d3;border:1px solid #c4a67c;border-radius:8px;box-shadow:0 4px 16px #00000040;overflow:hidden;z-index:50}.scrabble-page .dropup-menu button{display:block;width:100%;padding:.875rem 1rem;border:none;background:#f5e6d3;text-align:left;font-size:.9375rem;font-family:inherit;color:#4a3728;cursor:pointer;transition:background-color .1s}.scrabble-page .dropup-menu button:hover{background:#e8d4bc}.scrabble-page .dropup-menu button:not(:last-child){border-bottom:1px solid #d4c4a8}.scrabble-page .dropup-menu button.danger{color:#c62828}.scrabble-page .dropup-menu button.danger:hover{background:#ffebee}.scrabble-page .header-score.current-turn{color:#ffd54f;font-weight:800}.exchange-tiles{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin:1rem 0}.exchange-tiles .rack-tile{width:44px;height:48px}.scrabble-page .blank-modal{max-width:320px;background:#f5e6d3}.scrabble-page .modal-title{color:#4a3728}.scrabble-page .letter-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.375rem;margin:1rem 0}.scrabble-page .letter-btn{aspect-ratio:1;border:1px solid #c4a67c;border-radius:4px;background:linear-gradient(135deg,#f5e6d3,#e8d4bc);cursor:pointer;font-size:1.125rem;font-weight:700;color:#4a3728;font-family:Georgia,Times New Roman,serif;transition:background-color .1s,transform .1s,box-shadow .1s;box-shadow:0 2px 4px #00000026}.scrabble-page .letter-btn:hover{background:linear-gradient(135deg,#e8d4bc,#dcc4a8);transform:scale(1.05);box-shadow:0 3px 6px #0003}.scrabble-page .letter-btn:active{background:linear-gradient(135deg,#c8e6c9,#a5d6a7);transform:scale(.95)}.scrabble-page .tile-bag-modal{max-width:360px;background:#f5e6d3}.scrabble-page .tile-bag-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin:1rem 0}.scrabble-page .tile-bag-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:linear-gradient(135deg,#fff,#f5e6d3);border:1px solid #c4a67c;border-radius:4px;box-shadow:0 1px 3px #0000001a}.scrabble-page .tile-bag-letter{font-family:Georgia,Times New Roman,serif;font-weight:700;font-size:1rem;color:#4a3728}.scrabble-page .tile-bag-count{font-size:.75rem;color:#8b7355;font-weight:600}.scrabble-page .history-modal{max-width:440px;background:#f5e6d3}.scrabble-page .history-list{max-height:50vh;overflow-y:auto;margin:1rem 0}.scrabble-page .history-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #d4c4a8}.scrabble-page .history-item:last-child{border-bottom:none}.scrabble-page .history-move-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#d4c4a8;border-radius:50%;font-size:.75rem;font-weight:700;color:#6d5344;flex-shrink:0}.scrabble-page .history-details{flex:1;display:flex;flex-direction:column;gap:.125rem}.scrabble-page .history-player{font-weight:600;font-size:.9375rem;color:#4a3728}.scrabble-page .history-type{font-size:.8125rem;color:#8b7355}.scrabble-page .history-score{font-weight:700;color:#558b2f;font-size:.9375rem}.scrabble-page .alert{background:#8b5a2b99;border-radius:4px;margin-bottom:.5rem}.scrabble-page .alert-error{background:#c6282833;border-color:#c6282880;color:#ffcdd2}@media (max-width: 400px){.scrabble-container{padding:.375rem}.scrabble-cell{width:28px;height:28px}.scrabble-tile .tile-letter{font-size:.9375rem}.scrabble-tile .tile-points{font-size:.5rem;bottom:1px;right:2px}.bonus-label{font-size:.5rem}.scrabble-rack{gap:.25rem;padding:.5rem .75rem}.rack-tile{width:38px;height:42px}.rack-tile .tile-letter{font-size:1.25rem}.rack-tile .tile-value{font-size:.5rem;bottom:3px;right:4px}.rack-tile .blank-indicator{font-size:1.125rem}.scrabble-actions{padding:.5rem .625rem;gap:.375rem}.actions-left{gap:.25rem}.scrabble-actions .btn-icon{min-width:36px;width:36px;min-height:36px;font-size:1rem}.actions-scores{gap:.375rem;font-size:.8125rem}.scrabble-actions .btn-play{min-width:72px;min-height:36px;padding:.375rem .75rem;font-size:.75rem}.scrabble-page .dropup-menu{min-width:120px}.scrabble-page .dropup-menu button{padding:.75rem .875rem;font-size:.875rem}.scrabble-page .tile-bag-grid{grid-template-columns:repeat(4,1fr)}.scrabble-page .letter-grid{grid-template-columns:repeat(6,1fr)}.scrabble-page .letter-btn{font-size:1rem}}@media (max-width: 340px){.scrabble-cell{width:24px;height:24px}.scrabble-board{gap:1px;padding:3px}.scrabble-row{gap:1px}.scrabble-tile .tile-letter{font-size:.8125rem}.rack-tile{width:34px;height:38px}.rack-tile .tile-letter{font-size:1.125rem}.scrabble-actions{padding:.375rem .5rem}.scrabble-actions .btn-icon{min-width:32px;width:32px;min-height:32px;font-size:.875rem}.actions-scores{gap:.25rem;font-size:.75rem}.scrabble-actions .btn-play{min-width:64px;min-height:32px;padding:.25rem .5rem;font-size:.6875rem}}.battleship-page{background:linear-gradient(180deg,#0a1628,#0d2137,#0a1628);min-height:100vh;min-height:100dvh}.battleship-page .header{background:#0a1628f2;border-bottom:1px solid rgba(100,180,255,.2)}.battleship-page .header-logo{color:#64b4ff}.battleship-page .hamburger span{background:#64b4ff}.battleship-container{padding:.75rem;display:flex;flex-direction:column;height:calc(100vh - 53px);height:calc(100dvh - 53px);overflow:auto;-webkit-overflow-scrolling:touch}.battleship-header{text-align:center;padding:.75rem 1rem;background:#14325099;border:1px solid rgba(100,180,255,.3);border-radius:8px;margin-bottom:.75rem;flex-shrink:0}.battleship-header h2{color:#64b4ff;font-size:1.25rem;margin:0 0 .25rem;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.battleship-header .text-muted{color:#64b4ff99;font-size:.875rem}.battleship-scores{display:flex;justify-content:center;align-items:center;gap:1rem;font-size:.9375rem}.player-status{color:#64b4ffb3;font-weight:500}.player-status.current-turn{color:#4ade80;font-weight:700}.status-divider{color:#64b4ff66}.game-result-inline{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fbbf24;margin-left:.5rem;padding-left:.75rem;border-left:1px solid rgba(100,180,255,.3)}.battleship-grids{flex:1;display:flex;flex-direction:column;gap:.75rem;min-height:0;overflow:auto}.battleship-setup-grid{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.grid-section{display:flex;flex-direction:column;align-items:center}.grid-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:#64b4ff80;margin-bottom:.375rem}.battleship-grid{display:flex;flex-direction:column;gap:2px;padding:4px;background:#14325066;border:1px solid rgba(100,180,255,.3);border-radius:4px;box-shadow:0 0 20px #64b4ff1a,inset 0 0 30px #0000004d;position:relative;overflow:hidden;flex-shrink:0}.battleship-row{display:flex;gap:2px}.battleship-cell{width:28px;height:28px;background:#0a1e3ccc;border:1px solid rgba(100,180,255,.15);border-radius:2px;cursor:pointer;transition:all .15s ease;position:relative;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media (hover: hover){.battleship-cell:hover{background:#28507899;border-color:#64b4ff66}}.battleship-cell.ship{background:repeating-linear-gradient(45deg,#64b4ff4d,#64b4ff4d 3px,#3264964d 3px,#3264964d 6px);border-color:#64b4ff66}.battleship-cell.hit{background:radial-gradient(circle,#ef4444 30%,#ef44444d 70%);border-color:#ef4444}.battleship-cell.hit:after{content:"×";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.25rem;font-weight:700;color:#fff;text-shadow:0 0 4px rgba(0,0,0,.5)}.battleship-cell.miss{background:#0a1e3ccc;border-color:#64b4ff33}.battleship-cell.miss:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#64b4ff66;border-radius:50%}.battleship-cell.targeted{background:#fbbf244d;border-color:#fbbf24;box-shadow:0 0 8px #fbbf2480}.battleship-cell.targeted:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid #fbbf24;border-radius:50%}.battleship-cell.firing{overflow:visible}.battleship-cell.firing:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:10px;height:14px;background:linear-gradient(180deg,#374151,#1f2937,#ef4444);border-radius:50% 50% 40% 40%;animation:bombDrop .6s ease-in forwards;z-index:100}.battleship-cell.firing:before{animation:crosshairPulse .6s ease-out forwards}@keyframes bombDrop{0%{top:-60px;opacity:1;transform:translate(-50%) scale(.8)}70%{top:30%;opacity:1;transform:translate(-50%) scale(1)}85%{top:50%;transform:translate(-50%) scale(1.2)}to{top:50%;opacity:0;transform:translate(-50%) scale(2)}}@keyframes crosshairPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.8}to{transform:translate(-50%,-50%) scale(0);opacity:0}}.battleship-cell.firing{animation:impactFlash .6s ease-out forwards}@keyframes impactFlash{0%,70%{background:#fbbf244d}85%{background:#fffc;box-shadow:0 0 20px #fffc}to{background:#fbbf244d}}.battleship-cell.hover-valid{background:#4ade804d;border-color:#4ade80}.battleship-cell.hover-invalid{background:#ef44444d;border-color:#ef4444}.enemy-grid .battleship-cell{cursor:crosshair}.battleship-ship-selector{background:#14325066;border:1px solid rgba(100,180,255,.2);border-radius:8px;padding:.75rem;margin-top:.75rem;width:100%;max-width:360px}.ship-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:#64b4ffb3;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.ship-selector-header .btn{background:#64b4ff1a;border-color:#64b4ff4d;color:#64b4ff;padding:.375rem .75rem;min-height:32px;font-size:.75rem}.ship-selector-header .btn:hover{background:#64b4ff33;border-color:#64b4ff80;color:#64b4ff}.ship-list{display:flex;flex-direction:column;gap:.375rem}.ship-btn{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background:#0a1e3c99;border:1px solid rgba(100,180,255,.2);border-radius:4px;cursor:pointer;transition:all .15s;font-family:inherit}.ship-btn:hover{background:#1e3c6499;border-color:#64b4ff66}.ship-btn.selected{background:#4ade8033;border-color:#4ade80}.ship-name{color:#64b4ff;font-size:.875rem;font-weight:500}.ship-size{display:flex;gap:3px}.ship-dot{width:12px;height:12px;background:#64b4ff66;border:1px solid rgba(100,180,255,.6);border-radius:2px}.ship-btn.selected .ship-dot{background:#4ade8066;border-color:#4ade80}.placed-ships{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(100,180,255,.15)}.placed-label{color:#64b4ff80;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;width:100%;margin-bottom:.25rem}.placed-ship-btn{background:#64b4ff26;border:1px solid rgba(100,180,255,.3);border-radius:4px;padding:.25rem .5rem;color:#64b4ff;font-size:.75rem;font-family:inherit;cursor:pointer;transition:all .15s}.placed-ship-btn:hover{background:#ef444433;border-color:#ef4444;color:#ef4444}.battleship-actions{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#14325099;border:1px solid rgba(100,180,255,.2);border-radius:8px;margin-top:.75rem;flex-shrink:0}.battleship-actions .btn-secondary{background:#64b4ff1a;border-color:#64b4ff4d;color:#64b4ff}.battleship-actions .btn-secondary:hover{background:#64b4ff33;border-color:#64b4ff80;color:#64b4ff}.battleship-actions .btn-primary{background:linear-gradient(180deg,#4ade80,#22c55e);border:none;color:#0a1628;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.battleship-actions .btn-primary:hover{background:linear-gradient(180deg,#5eeb94,#34d369)}.battleship-actions .btn-primary:disabled{background:#64b4ff33;color:#64b4ff66}.battleship-actions .btn-play{min-width:100px;padding:.625rem 1.5rem}.battleship-console{flex:1;text-align:center;padding:.5rem .75rem;background:#0000004d;border:1px solid rgba(100,180,255,.2);border-radius:4px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.8125rem;color:#4ade80;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.battleship-page .alert{background:#14325099;border-radius:4px;margin-bottom:.75rem}.battleship-page .alert-error{background:#ef444426;border-color:#ef444466;color:#fca5a5}.battleship-page .alert-success{background:#4ade8026;border-color:#4ade8066;color:#86efac}.battleship-grid:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(100,180,255,.4) 50%,transparent 100%);animation:radarScan 3s linear infinite;pointer-events:none}@keyframes radarScan{0%{top:0;opacity:1}to{top:100%;opacity:0}}@media (max-width: 400px){.battleship-container{padding:.5rem}.battleship-cell{width:24px;height:24px}.battleship-header{padding:.5rem .75rem}.battleship-header h2{font-size:1rem}.battleship-scores{font-size:.8125rem;gap:.5rem}.battleship-actions{padding:.625rem .75rem}.battleship-ship-selector{padding:.5rem;margin-top:.5rem}.ship-selector-header{margin-bottom:.5rem}.ship-btn{padding:.5rem .625rem}.ship-name{font-size:.8125rem}.ship-dot{width:10px;height:10px}.ship-list{gap:.25rem}.placed-ships{margin-top:.5rem;padding-top:.5rem}.grid-label{margin-bottom:.25rem}}@media (max-width: 340px){.battleship-cell{width:22px;height:22px}.battleship-grid{gap:1px;padding:3px}.battleship-row{gap:1px}.ship-dot{width:8px;height:8px}.ship-name{font-size:.75rem}.battleship-scores{flex-wrap:wrap;font-size:.75rem}.player-status{font-size:.75rem}}.mastermind-page{background:#2a2a2a;min-height:100vh;min-height:100dvh}.mastermind-page .header{background:#1f1f1f;border-bottom:1px solid #444}.mastermind-page .header-logo{color:#ccc}.mastermind-page .hamburger span{background:#ccc}.mm-toggle{color:#666;font-size:.6875rem}.mm-board-collapsible .mm-board-header{margin-bottom:0;padding-bottom:0;border-bottom:none}.mm-board-collapsible .mm-rows,.mm-board-collapsible>.mm-row{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #444}.mm-container{padding:.5rem;display:flex;flex-direction:column;gap:.75rem}.mm-loading{color:#888;text-align:center}.mm-header{text-align:center}.mm-header h2{color:#e0e0e0;font-size:1.125rem;margin-bottom:.25rem}.mm-sub{color:#777;font-size:.8125rem}.mm-status{display:flex;align-items:center;justify-content:center;gap:.5rem}.mm-status span{color:#888;font-size:.9375rem}.mm-status span.active{color:#fff;font-weight:600}.mm-status .vs{color:#555;font-size:.75rem}.mm-result{color:#e0e0e0;font-weight:600;margin-top:.25rem}.mm-info{color:#666;font-size:.75rem;margin-top:.25rem}.mm-peg{width:32px;height:32px;border-radius:50%;border:2px solid #555;background:#3a3a3a;box-shadow:inset 0 2px 4px #0000004d}.mm-peg.selected{border-color:#888;box-shadow:0 0 0 2px #666}.mm-peg-sm{width:24px;height:24px;border-radius:50%;border:2px solid #555;background:#3a3a3a;box-shadow:inset 0 1px 2px #0000004d}.mm-peg-xs{width:14px;height:14px;border-radius:50%;border:1px solid #555;background:#3a3a3a;display:flex;align-items:center;justify-content:center;font-size:.5rem;color:#666}.mm-peg-xs.mystery{background:#333}.mm-feedback{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;width:24px}.fb-dot{width:8px;height:8px;border-radius:50%;background:#444;border:1px solid #555}.fb-dot.exact{background:#1a1a1a;border-color:#333}.fb-dot.partial{background:#e0e0e0;border-color:#ccc}.mm-input-area{background:#333;border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.mm-slots{display:flex;gap:.5rem}.mm-slot{padding:3px;border-radius:50%;cursor:pointer}.mm-slot.selected{background:#555}.mm-palette{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.mm-color-btn{width:20px;height:20px;border-radius:50%;border:1px solid #555;cursor:pointer;transition:transform .15s;box-shadow:inset 0 2px 4px #0000004d}.mm-color-btn:hover:not(:disabled){transform:scale(1.1);border-color:#888}.mm-color-btn:disabled,.mm-color-btn.used{opacity:.3;cursor:not-allowed}.mm-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%}.mm-msg{flex:1;text-align:center;color:#888;font-size:.8125rem}.mm-boards{display:flex;flex-direction:column;gap:.5rem}.mm-board{background:#333;border-radius:8px;padding:.75rem}.mm-board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #444;font-size:.8125rem;color:#999}.mm-mini{display:flex;gap:2px}.mm-rows{display:flex;flex-direction:column;gap:.375rem}.mm-row{display:flex;align-items:center;gap:.5rem;padding:.375rem;background:#3a3a3a;border-radius:4px}.mm-row-num{color:#666;font-size:.6875rem;width:16px;text-align:center}.mm-pegs{display:flex;gap:.25rem}.mm-empty{color:#555;font-size:.75rem;text-align:center;padding:.5rem}.mm-your-secret{display:flex;align-items:center;gap:.75rem;color:#888;font-size:.875rem;padding:1rem;background:#333;border-radius:8px;justify-content:center}.mastermind-page .btn{font-size:.875rem}.mastermind-page .btn-primary{background:#555;border-color:#666;color:#fff}.mastermind-page .btn-primary:hover:not(:disabled){background:#666}.mastermind-page .btn-primary:disabled{background:#3a3a3a;border-color:#444;color:#666}.mastermind-page .btn-secondary{background:transparent;border-color:#555;color:#999}.mastermind-page .btn-secondary:hover{background:#3a3a3a;color:#ccc}.mastermind-page .alert-error{background:#3a2a2a;border-color:#633;color:#c88}.difficulty-options{display:flex;flex-direction:column;gap:.75rem}.option-group{display:flex;align-items:center;gap:.75rem}.option-label{color:#666;font-size:.875rem;min-width:60px}.option-buttons{display:flex;gap:.375rem}.option-btn{padding:.375rem .75rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;cursor:pointer;font-size:.8125rem;transition:all .15s}.option-btn:hover{background:#f5f5f5}.option-btn.selected{background:#121212;border-color:#121212;color:#fff}.friend-select-btn.selected{background:#121212;color:#fff}@media (max-width: 400px){.mm-peg{width:28px;height:28px}.mm-peg-sm{width:20px;height:20px}.mm-color-btn{width:30px;height:30px}}.memory-page{background:linear-gradient(180deg,#1a1a2e,#16213e,#0f3460);min-height:100vh;min-height:100dvh}.memory-page .header{background:#0f1428f2;border-bottom:1px solid rgba(120,160,255,.2)}.memory-page .header-logo{color:#a8c0ff}.memory-page .hamburger span{background:#a8c0ff}.mem-container{padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.mem-loading{color:#89b;text-align:center;padding:2rem}.mem-header{text-align:center;padding:.75rem 1rem;background:#141e3c99;border:1px solid rgba(120,160,255,.2);border-radius:8px}.mem-scores{display:flex;justify-content:center;align-items:center;gap:.75rem;font-size:1rem;font-weight:600}.mem-player{color:#a8c0ff99;padding:.125rem .5rem;border-radius:4px}.mem-player.active{color:#a8c0ff;background:#78a0ff26}.mem-divider{color:#78a0ff4d}.mem-info{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:.375rem;font-size:.8125rem;color:#a8c0ff80}.mem-result{font-weight:700;color:#fbbf24;text-transform:uppercase;letter-spacing:.05em}.mem-pairs{font-size:.75rem}.mem-message{text-align:center;font-weight:600;color:#a8c0ff;font-size:.9375rem;padding:.375rem;background:#78a0ff1a;border-radius:6px}.mem-board-wrapper{display:flex;justify-content:center;padding:.25rem}.mem-grid{display:grid;gap:6px;width:100%;max-width:480px}.mem-tile{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.mem-tile.hidden{background:linear-gradient(135deg,#2a3a5c,#1e2d4d);border:1px solid rgba(120,160,255,.2);box-shadow:0 2px 4px #0000004d}.mem-tile.hidden.clickable{cursor:pointer}@media (hover: hover){.mem-tile.hidden.clickable:hover{border-color:#78a0ff80;box-shadow:0 2px 8px #78a0ff33;transform:scale(1.03)}}.mem-tile.selected{background:linear-gradient(135deg,#3a4a7c,#2e3d6d);border:2px solid #a8c0ff;box-shadow:0 0 12px #78a0ff4d}.mem-tile.revealed,.mem-tile.just-matched{background:#1e2846cc;border:1px solid rgba(120,160,255,.4)}.mem-tile.just-matched{border-color:#4ade80;box-shadow:0 0 12px #4ade804d}.mem-tile.matched{background:#141e3280;border:1px solid rgba(120,160,255,.15);opacity:.75}.mem-tile.replay{background:#1e2846cc;border:1px solid rgba(251,191,36,.5);box-shadow:0 0 10px #fbbf2433;animation:replayFade 1.2s ease-out forwards}@keyframes replayFade{0%{opacity:1}70%{opacity:1}to{opacity:.6}}.mem-tile-face{width:65%;height:65%;display:flex;align-items:center;justify-content:center}.mem-tile-back{width:40%;height:40%;border-radius:50%;background:#78a0ff1a;border:1px solid rgba(120,160,255,.15)}.mem-tile-selected-dot{width:30%;height:30%;border-radius:50%;background:#a8c0ff;box-shadow:0 0 8px #a8c0ff80}.mem-actions{display:flex;justify-content:center;gap:.75rem}.memory-page .btn-primary{background:linear-gradient(180deg,#4a6cf7,#3b5de7);border:none;color:#fff}.memory-page .btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#5a7cf7,#4b6de7)}.memory-page .btn-secondary{background:#78a0ff1a;border-color:#78a0ff4d;color:#a8c0ff}.memory-page .btn-secondary:hover{background:#78a0ff33;border-color:#78a0ff80;color:#a8c0ff}.mem-history{background:#141e3c80;border:1px solid rgba(120,160,255,.15);border-radius:8px;padding:.75rem}.mem-history-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#a8c0ff80;margin-bottom:.5rem}.mem-history-list{display:flex;flex-direction:column;gap:.375rem}.mem-history-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;background:#141e3280;border-radius:4px;font-size:.8125rem}.mem-history-item.match{background:#4ade801a}.mem-history-player{color:#a8c0ffb3;min-width:60px;font-weight:500}.mem-history-tiles{display:flex;gap:.25rem;flex:1}.mem-history-result{color:#a8c0ff80;font-size:.75rem}.mem-history-item.match .mem-history-result{color:#4ade80;font-weight:600}.memory-page .alert{background:#141e3c99;border-radius:4px}.memory-page .alert-error{background:#ef444426;border-color:#ef444466;color:#fca5a5}.mem-emoji{font-size:clamp(24px,4vw,40px);display:flex;align-items:center;justify-content:center;height:100%;-webkit-user-select:none;user-select:none}.mem-history-emoji{font-size:20px}@media (max-width: 400px){.mem-grid{gap:4px}.mem-scores{font-size:.875rem;gap:.5rem}.mem-header{padding:.5rem .75rem}}@media (max-width: 340px){.mem-grid{gap:3px}.mem-tile{border-radius:4px}}
