*{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 1.5rem;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-color:#faf8f5;overflow:hidden}.scrabble-page .header{flex-shrink:0;background:#faf8f5;border-bottom-color:#e0dcd4}.scrabble-container{padding:.5rem;display:flex;flex-direction:column;height:calc(100vh - 53px);overflow:hidden}.scrabble-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;background:#fff;border:1px solid #e0dcd4;border-radius:8px;margin-bottom:.5rem;flex-wrap:wrap;gap:.25rem;flex-shrink:0}.scrabble-header-scores{display:flex;align-items:center;gap:.625rem;font-size:.9375rem;font-weight:600}.header-score.you{color:#121212}.header-score.them{color:#666}.header-bag{color:#666;font-weight:500}.header-divider{color:#ccc}.scrabble-header-status{display:flex;align-items:center;gap:.5rem}.header-status{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#666}.header-status.your-turn{color:#2e7d32}.header-status.ended{color:#121212}.header-message{color:#2e7d32;font-weight:600}.header-error{color:#c62828;font-weight:500}.scrabble-board-wrapper{flex:1;min-height:0;max-height:55vh;overflow:scroll;border-radius:8px;background:#f0ebe3;border:1px solid #d4cfc4;margin-bottom:.5rem;cursor:grab;-webkit-overflow-scrolling:touch;touch-action:none}.scrabble-board-wrapper:active{cursor:grabbing}.scrabble-board{display:block;cursor:pointer}.scrabble-preview{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:4px;margin-bottom:.5rem;font-size:.9375rem;flex-shrink:0}.scrabble-preview.valid{background-color:#e8f5e9;color:#2e7d32}.scrabble-preview.invalid{background-color:#ffebee;color:#c62828}.preview-content{display:flex;align-items:center;gap:.5rem}.preview-content strong{font-size:1.125rem}.scrabble-rack{display:flex;justify-content:center;gap:.5rem;padding:.5rem;background:#fff;border:1px solid #e0dcd4;border-radius:8px;margin-bottom:.5rem;flex-wrap:wrap;flex-shrink:0}.rack-tile{width:36px;height:36px;border:1px solid #c4bfb4;border-radius:4px;background:#f8f4eb;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:transform .1s,box-shadow .1s,border-color .1s;box-shadow:0 2px #c4bfb4;font-family:Georgia,Times New Roman,serif}.rack-tile:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0000001f;border-color:#121212}.rack-tile.selected{background:#ffd54f;border-color:#f9a825;transform:translateY(-4px);box-shadow:0 6px 12px #00000026}.rack-tile:disabled{opacity:.5;cursor:not-allowed}.rack-tile.blank{background:#fff;border-style:dashed}.blank-indicator{font-size:1.5rem;font-weight:700;color:#999}.tile-letter{font-size:1.5rem;font-weight:700;color:#121212}.tile-value{font-size:.625rem;font-weight:700;color:#666;position:absolute;bottom:2px;right:4px;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif}.scrabble-actions{display:flex;gap:.5rem;justify-content:center;margin-bottom:.5rem;flex-wrap:wrap;flex-shrink:0}.scrabble-actions .btn{min-height:44px;padding:.5rem 1.25rem;font-size:.9375rem;border-radius:4px}.btn-large{min-width:80px;font-weight:700}.scrabble-menu{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;flex-shrink:0}.scrabble-menu .btn{min-height:40px;padding:.5rem 1rem;font-size:.875rem;border-radius:4px}.exchange-tiles{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin:1rem 0}.blank-modal{max-width:320px}.letter-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.375rem;margin:1rem 0}.letter-btn{aspect-ratio:1;border:1px solid #e0e0e0;border-radius:4px;background:#fff;cursor:pointer;font-size:1.125rem;font-weight:700;color:#121212;font-family:Georgia,Times New Roman,serif;transition:background-color .1s,transform .1s,border-color .1s}.letter-btn:hover{background:#f7f7f7;border-color:#121212;transform:scale(1.05)}.letter-btn:active{background:#ffd54f;transform:scale(.95)}@media (max-width: 400px){.scrabble-container{padding:.375rem}.scrabble-rack{gap:.375rem;padding:.75rem}.rack-tile{width:42px;height:42px}.tile-letter,.blank-indicator{font-size:1.25rem}.scrabble-header{padding:.5rem .75rem}.scrabble-header-scores{font-size:.875rem}.scrabble-actions .btn{min-height:40px;padding:.375rem 1rem;font-size:.875rem}.scrabble-menu .btn{min-height:36px;padding:.375rem .75rem;font-size:.8125rem}.letter-grid{grid-template-columns:repeat(6,1fr)}.letter-btn{font-size:1rem}}.exchange-tiles .rack-tile{width:44px;height:44px}
