@import"https://fonts.googleapis.com/css2?family=Caprasimo&family=Roboto+Slab:wght@400;700&display=swap";*{box-sizing:border-box}html{font-family:Roboto Slab,sans-serif;line-height:1.5;color:#ebe7ef;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{background:radial-gradient(circle at top,rgba(241,210,70,.98),rgba(250,176,103,.87)),url(bg-pattern-dark.png);background-repeat:repeat;background-size:100% 100%,30% 30%,100% 100%;min-height:110rem}header{text-align:center}header img{width:8rem;object-fit:contain;margin:3rem auto 1rem;filter:drop-shadow(0 0 8px rgba(0,0,0,.4))}h1{font-family:Caprasimo,cursive;font-size:3rem;margin:0 auto 3rem;color:#3f3b00}#game-container{max-width:55rem;margin:3rem auto;padding:2rem;border-radius:14px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 30px #0a0a0a59;position:relative;-webkit-backdrop-filter:blur(8px) saturate(120%);backdrop-filter:blur(8px) saturate(120%)}#players{list-style:none;padding:0;margin:1rem 0;display:flex;justify-content:center;align-items:center;gap:2rem}#players li{display:flex;align-items:center;width:50%;border:2px solid transparent}#players.highlight-player li.active{border-color:#f6e35a;animation:pulse 2s infinite ease-in-out}#players.highlight-player li.active .player-name,#players.highlight-player li.active .player-symbol{color:#f6e35a}#players button{width:3rem;border:none;background:linear-gradient(180deg,rgba(20,18,14,.55),rgba(10,10,8,.45));color:#d9cf9e;font-size:.9rem;cursor:pointer;transition:color .2s,background .12s;padding:.5rem .25rem;text-align:center;border-radius:6px}#players button:hover{color:#f8ca31}.player{border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));padding:.5rem;border-radius:8px;font-weight:700;display:flex;align-items:center;gap:.5rem}.player-name{display:inline-block;width:10rem;font-size:1rem;color:#d9d6bf;margin:0;padding:.5rem;border-radius:4px;text-overflow:ellipsis;text-align:center;background:linear-gradient(180deg,rgba(0,0,0,.58),rgba(10,10,10,.45));border:1px solid rgba(255,255,255,.03);box-shadow:inset 0 1px #ffffff05}.player input{font:inherit;font-size:1rem;width:10rem;border:none;padding:.5rem;animation:pulse-text 2s infinite;background-color:#2b2a22;text-align:center}.player-symbol{margin-left:1rem;font-size:1.4rem;color:#f6e35a;font-weight:900}ol{list-style:none;margin:0;padding:0}#pre-game{text-align:center}#pre-game button{cursor:pointer;background:none;color:#f8c031;border:none;font-family:Caprasimo,cursive;font-size:4rem;text-shadow:0 0 12px rgba(0,0,0,.7);animation:pulse-text-size 2s infinite ease-out}#game-board{display:grid;grid-template-columns:repeat(3,minmax(5rem,1fr));gap:1.25rem;margin:2rem auto;padding:0;width:min(36rem,100%);list-style:none}#game-board>li{list-style:none}#game-board button{width:100%;aspect-ratio:1 / 1;border:none;background:linear-gradient(180deg,rgba(0,0,0,.58),rgba(10,10,10,.45));color:#f6e35a;font-size:6rem;font-weight:900;line-height:1;-webkit-text-stroke:.8px rgba(0,0,0,.6);cursor:pointer;font-family:Caprasimo,cursive;padding:.25rem;border-radius:10px;box-shadow:0 8px 26px #0000008c,inset 0 1px #ffffff05;text-shadow:0 3px 8px rgba(0,0,0,.65);transition:transform .12s ease,box-shadow .12s ease,background .12s ease}#game-board button[disabled]{opacity:.8;cursor:not-allowed;background:linear-gradient(180deg,rgba(0,0,0,.6),rgba(0,0,0,.5))}#game-board button:hover:not([disabled]){transform:translateY(-4px);box-shadow:0 12px 30px #00000073}#game-board button:focus-visible{outline:3px solid #ffd54a;outline-offset:4px}#game-over{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#282617f2;animation:pop-in .5s cubic-bezier(.68,-.55,.65,.52) forwards;z-index:100}#game-over h2{font-family:Caprasimo,cursive;font-size:4rem;text-align:center;color:#fcd256;margin:0}#game-over p{font-size:2rem;text-align:center;color:#e1dec7}#game-over button{display:block;margin:0 auto;font-size:1.5rem;background:linear-gradient(135deg,#fcd256,#f8b841);color:#3f3b00;padding:.75rem 2rem;border-radius:4px;cursor:pointer;transition:all .2s;border:none;font-weight:700;box-shadow:0 4px 12px #0006}#game-over button:hover{background:linear-gradient(135deg,#f8b841,#fcd256);transform:scale(1.1);box-shadow:0 6px 16px #00000080}#log{max-width:20rem;color:#3f3b00;list-style:none;margin:2rem auto;padding:0;text-align:center}#log li{border-radius:4px;animation:slide-in-from-left 1s cubic-bezier(.075,.82,.165,1) forwards;margin:.75rem}#log li.highlighted{background-color:#3f3b00;color:#fff}#game-hints{text-align:center;color:#46432f}#game-hints h2{font-family:Caprasimo,cursive;font-size:2rem;margin:0}#game-hints ul{list-style:none;padding:0;margin:0}#game-hints button{cursor:pointer;border:none;background:transparent;color:#23221f;font:inherit;margin-top:1.5rem}@keyframes slide-in-from-left{0%{opacity:0;transform:translate(-30%)}to{opacity:1;transform:translate(0)}}@keyframes pulse-text{0%{color:#e1dec7}50%{color:#9f9d83}to{color:#e1dec7}}@keyframes pulse-text-size{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes pulse{0%{border-color:#f6e35a;box-shadow:0 0 #f6e35a66}50%{border-color:#f8c031;box-shadow:0 0 0 .5rem #f8a53100}to{border-color:#f6e35a;box-shadow:0 0 #f6e35a00}}@keyframes pop-in{0%{transform:scale(0);opacity:0}80%{transform:scale(1.1);opacity:1}to{transform:scale(1)}}#stats-container{display:flex;justify-content:space-around;gap:2rem;margin:2rem 0;padding:1.5rem;background:linear-gradient(135deg,rgba(62,59,32,.6),rgba(70,67,47,.6));border-radius:8px;flex-wrap:wrap;align-items:flex-start}.stats-card{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));padding:1.25rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);min-width:140px;text-align:center;box-shadow:0 8px 20px #00000040}.stats-card h3{margin:0 0 1rem;color:#f6e35a;font-family:Roboto Slab,sans-serif;font-size:1.2rem}.stats-item{display:flex;justify-content:space-between;align-items:center;margin:.75rem 0;padding:.5rem;background:rgba(0,0,0,.3);border-radius:4px}.stat-label{color:#c3ba78;font-weight:700}.stat-value{color:#fcd256;font-size:1.2rem;font-weight:700;min-width:40px}.stat-value.wins{color:#6dd5ff}.stat-value.losses{color:#ff6b6b}.stat-value.draws{color:#ffd93d}.reset-stats-btn{background:linear-gradient(135deg,#5aa9ff,#2b7ed6);color:#fff;border:none;padding:.6rem 1rem;border-radius:8px;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease;font-size:.9rem;align-self:flex-end;box-shadow:0 6px 16px #2b7ed640}.reset-stats-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #ff6b6b4d}.reset-stats-btn:active{transform:translateY(0)}button:focus{outline:none}button:focus-visible,input:focus-visible{outline:3px solid #ffd54a;outline-offset:3px}.player-name,.player-symbol,.stat-label,.stat-value{color:#f3f4f6}@media (max-width: 768px){#stats-container{flex-direction:column}.stats-card{width:100%}#game-board button{width:6rem;height:6rem;font-size:3rem}#players{flex-direction:column;gap:1rem}#players li{width:100%}h1{font-size:2rem}}@media (max-width: 480px){#game-container{padding:1rem;margin:1rem auto}h1{font-size:1.5rem;margin:1rem auto 1.5rem}#game-board button{width:5rem;height:5rem;font-size:2.5rem;gap:1rem}#game-board ol,#game-board{gap:1rem}#players{gap:.5rem}.player-name,.player input{width:8rem;font-size:.85rem}.player-symbol{margin-left:.5rem;font-size:.9rem}#game-over h2{font-size:2.5rem}#game-over p{font-size:1.2rem}#game-over button{font-size:1.1rem;padding:.6rem 1.5rem}.stats-card{min-width:120px;padding:1rem}.stat-label{font-size:.9rem}.stat-value{font-size:1rem}}
