@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";.app{min-height:100vh;position:relative;overflow-x:hidden}.ocean-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden}.wave{position:absolute;width:200%;height:100%;background:linear-gradient(180deg,#0077be1a,#0483,#0022444d);animation:wave 20s ease-in-out infinite}.wave:nth-child(2){animation-delay:-5s;opacity:.7}.wave:nth-child(3){animation-delay:-10s;opacity:.5}.bubbles{position:fixed;width:100%;height:100%;z-index:0;pointer-events:none}.bubble{position:absolute;bottom:-50px;width:40px;height:40px;background:radial-gradient(circle,#ffffff4d,#fff0 70%);border-radius:50%;animation:bubble 15s infinite;opacity:0}.bubble:nth-child(1){left:10%;animation-delay:0s;width:20px;height:20px}.bubble:nth-child(2){left:20%;animation-delay:2s;width:30px;height:30px}.bubble:nth-child(3){left:35%;animation-delay:4s;width:25px;height:25px}.bubble:nth-child(4){left:50%;animation-delay:1s;width:35px;height:35px}.bubble:nth-child(5){left:65%;animation-delay:3s;width:28px;height:28px}.bubble:nth-child(6){left:80%;animation-delay:5s;width:22px;height:22px}.bubble:nth-child(7){left:90%;animation-delay:2.5s;width:32px;height:32px}.home-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:20px}.home-content{position:relative;z-index:1;text-align:center;max-width:900px;width:100%}.title-container{margin-bottom:60px;animation:float 6s ease-in-out infinite}.main-title{font-size:4.5rem;font-weight:700;margin-bottom:20px;text-shadow:0 0 20px rgba(135,206,250,.8),0 0 40px rgba(135,206,250,.6),0 0 60px rgba(135,206,250,.4);background:linear-gradient(135deg,#87ceeb,#4682b4,#1e90ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% auto;animation:shimmer 3s linear infinite}.subtitle{display:block;font-size:1.8rem;font-weight:300;margin-top:15px;color:#b0e0e6;text-shadow:0 2px 10px rgba(176,224,230,.5)}.school-intro{margin:60px 0;display:flex;flex-direction:column;align-items:center;gap:30px}.school-building{position:relative;width:200px;height:250px;animation:float 8s ease-in-out infinite}.building-top{width:0;height:0;border-left:100px solid transparent;border-right:100px solid transparent;border-bottom:60px solid rgba(255,215,0,.6);margin:0 auto;filter:drop-shadow(0 0 20px rgba(255,215,0,.8))}.building-body{width:180px;height:180px;background:linear-gradient(135deg,#4682b4b3,#1e90ffb3);margin:0 auto;border-radius:10px;display:flex;flex-wrap:wrap;justify-content:space-around;align-items:center;padding:20px;box-shadow:0 0 30px #87cefa80,inset 0 0 20px #fff3}.window{width:40px;height:40px;background:#ff0c;border-radius:5px;box-shadow:0 0 15px #ffff00e6,inset 0 0 10px #ffffff80;animation:float 3s ease-in-out infinite}.window:nth-child(2){animation-delay:1s}.window:nth-child(3){animation-delay:2s}.intro-text{font-size:1.3rem;line-height:2;color:#e0f6ff;text-shadow:0 2px 10px rgba(0,0,0,.5);max-width:700px;margin:0 auto}.enter-button{position:relative;margin-top:60px;padding:20px 50px;font-size:1.5rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#1e90ff,#00bfff,#87ceeb);border:none;border-radius:50px;cursor:pointer;overflow:hidden;transition:all .3s ease;box-shadow:0 10px 30px #1e90ff66,0 0 20px #87cefa99;z-index:1}.enter-button:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px #1e90ff99,0 0 30px #87cefacc}.enter-button:active{transform:translateY(-2px) scale(1.02)}.button-text{position:relative;z-index:2}.button-glow{position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}.enter-button:hover .button-glow{width:300px;height:300px}.floating-fish{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}.fish{position:absolute;font-size:3rem;animation:float 10s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}.fish-1{top:20%;left:10%;animation-delay:0s}.fish-2{top:60%;right:15%;animation-delay:3s;animation-duration:12s}.fish-3{bottom:20%;left:20%;animation-delay:6s;animation-duration:14s}@media (max-width: 768px){.main-title{font-size:3rem}.subtitle{font-size:1.3rem}.intro-text{font-size:1.1rem}.enter-button{padding:15px 40px;font-size:1.2rem}}.graduation-page{min-height:100vh;padding:40px 20px;position:relative}.graduation-content{position:relative;z-index:1;max-width:1200px;margin:0 auto}.graduation-header{text-align:center;margin-bottom:60px;animation:float 6s ease-in-out infinite}.graduation-title{font-size:3.5rem;font-weight:700;margin-bottom:15px;text-shadow:0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,215,0,.6);color:gold}.graduation-subtitle{font-size:1.5rem;color:#b0e0e6;text-shadow:0 2px 10px rgba(176,224,230,.5)}.ceremony-scene{margin:60px 0;display:flex;justify-content:center}.stage{position:relative;width:100%;max-width:600px;height:300px;background:linear-gradient(180deg,#ffd70033,#1e90ff4d,#0486);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 50px #ffd7004d,inset 0 0 30px #ffffff1a;overflow:hidden}.stage-lights{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.light{position:absolute;width:150px;height:150px;border-radius:50%;filter:blur(40px);animation:float 4s ease-in-out infinite}.light-1{background:#ff6b9d66;top:10%;left:10%;animation-delay:0s}.light-2{background:#4ecdc466;top:10%;right:10%;animation-delay:1.5s}.light-3{background:#ffe66d66;bottom:10%;left:50%;transform:translate(-50%);animation-delay:3s}.stage-content{position:relative;z-index:2;text-align:center}.principal{font-size:5rem;margin-bottom:20px;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(255,215,0,.8))}.stage-text{font-size:1.3rem;color:#e0f6ff;text-shadow:0 2px 10px rgba(0,0,0,.5)}.stories-section{margin:80px 0}.stories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:50px;flex-wrap:wrap;gap:20px}.stories-title{text-align:center;font-size:2.5rem;font-weight:600;margin:0;color:gold;text-shadow:0 0 20px rgba(255,215,0,.6);flex:1}.new-story-button{padding:12px 30px;font-size:1.1rem;color:#fff;background:linear-gradient(135deg,gold,orange);border:2px solid rgba(255,215,0,.8);border-radius:25px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600;box-shadow:0 5px 20px #ffd70066;position:relative;z-index:1000;pointer-events:auto}.new-story-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #ffd70099}.stories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-bottom:40px}.story-card{position:relative;background:linear-gradient(135deg,#1e90ff33,#0044884d);border:2px solid var(--story-color);border-radius:20px;padding:30px;cursor:pointer;transition:all .4s ease;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.story-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,var(--story-color) 0%,transparent 70%);opacity:0;transition:opacity .4s ease}.story-card:hover:before{opacity:.2}.story-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 20px 40px #0000004d,0 0 30px var(--story-color);border-color:var(--story-color)}.story-card-glow{position:absolute;top:50%;left:50%;width:0;height:0;background:var(--story-color);border-radius:50%;transform:translate(-50%,-50%);filter:blur(30px);opacity:0;transition:all .6s ease}.story-card:hover .story-card-glow{width:200px;height:200px;opacity:.4}.story-number{position:absolute;top:15px;right:15px;width:40px;height:40px;background:var(--story-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;color:#fff;box-shadow:0 0 15px var(--story-color)}.story-card-title{font-size:1.8rem;font-weight:600;margin-bottom:15px;color:#fff;position:relative;z-index:1;text-shadow:0 2px 10px rgba(0,0,0,.5)}.story-card-description{font-size:1.1rem;line-height:1.8;color:#e0f6ff;margin-bottom:20px;position:relative;z-index:1}.story-card-button{position:relative;z-index:1;color:var(--story-color);font-weight:500;font-size:1.1rem;transition:all .3s ease}.story-card:hover .story-card-button{transform:translate(10px);text-shadow:0 0 10px var(--story-color)}.story-card.locked{opacity:.6;cursor:pointer;position:relative}.story-card.locked:hover{opacity:.8}.lock-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.lock-icon{font-size:3rem;margin-bottom:10px;animation:float 2s ease-in-out infinite}.lock-overlay p{color:gold;font-weight:600;font-size:1.1rem;text-shadow:0 0 10px rgba(255,215,0,.8)}.user-story{border:3px dashed var(--story-color)}.user-story-badge{position:absolute;top:15px;right:15px;width:40px;height:40px;background:linear-gradient(135deg,gold,orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 0 15px #ffd700cc;z-index:5}.back-button{display:block;margin:40px auto 0;padding:12px 30px;font-size:1.1rem;color:#fff;background:#1e90ff4d;border:2px solid rgba(135,206,250,.5);border-radius:25px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.action-buttons{display:flex;gap:20px;justify-content:center;margin-top:40px;position:relative;z-index:1000;pointer-events:auto;flex-wrap:wrap}.aquarium-button{padding:12px 30px;font-size:1.1rem;color:#fff!important;background:linear-gradient(135deg,#ff6b9d,#ff8e9b)!important;border:2px solid rgba(255,107,157,.8)!important;border-radius:25px;cursor:pointer!important;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 5px 20px #ff6b9d66;position:relative;z-index:1000;pointer-events:auto!important;-webkit-user-select:none;user-select:none}.aquarium-button:hover{background:linear-gradient(135deg,#ff8e9b,#ff6b9d);border-color:#ff6b9dcc;transform:translateY(-3px);box-shadow:0 8px 30px #ff6b9d99}.report-button{padding:12px 30px;font-size:1.1rem;color:#fff!important;background:linear-gradient(135deg,#ff4757,#ff6b9d)!important;border:2px solid rgba(255,71,87,.8)!important;border-radius:25px;cursor:pointer!important;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 5px 20px #ff475766;position:relative;z-index:1000;pointer-events:auto!important;-webkit-user-select:none;user-select:none;font-weight:600}.report-button:hover{background:linear-gradient(135deg,#ff6b9d,#ff4757)!important;border-color:#ff4757!important;transform:translateY(-3px);box-shadow:0 8px 30px #ff475799}.back-button:hover{background:#1e90ff80;border-color:#87cefacc;transform:translate(-5px);box-shadow:0 5px 20px #1e90ff66}@media (max-width: 768px){.graduation-title{font-size:2.5rem}.stories-grid{grid-template-columns:1fr}.stage{height:250px}.principal{font-size:4rem}}.word-game-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.word-game-container{background:linear-gradient(135deg,#002244f2,#004488f2);border-radius:20px;padding:40px;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;border:3px solid rgba(135,206,250,.5);box-shadow:0 20px 60px #00000080}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.game-header h2{color:gold;font-size:2rem;margin:0;text-shadow:0 0 20px rgba(255,215,0,.8)}.close-button{background:#ff6b9d4d;border:2px solid rgba(255,107,157,.5);color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .3s ease}.close-button:hover{background:#ff6b9d80;transform:rotate(90deg)}.progress-section{margin-bottom:30px}.progress-bar-container{width:100%;height:20px;background:#fff3;border-radius:10px;overflow:hidden;margin-bottom:10px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#1e90ff,#00bfff,#87ceeb);border-radius:10px;transition:width .5s ease;box-shadow:0 0 20px #87cefa99}.progress-text{text-align:center;color:#e0f6ff;font-size:1.1rem;font-weight:500}.word-content{display:flex;flex-direction:column;gap:20px}.word-card{background:#0000004d;border-radius:20px;padding:30px;border:2px solid rgba(135,206,250,.3)}.word-number{text-align:center;color:gold;font-size:1.2rem;font-weight:600;margin-bottom:25px;text-shadow:0 0 10px rgba(255,215,0,.6)}.word-meaning,.word-example{margin-bottom:20px}.word-meaning h3,.word-example h3{color:#87ceeb;font-size:1.1rem;margin-bottom:10px}.meaning-text{color:gold;font-size:1.8rem;font-weight:600;text-align:center;padding:15px;background:#ffd7001a;border-radius:10px;border:2px solid rgba(255,215,0,.3)}.example-text{color:#e0f6ff;font-size:1.2rem;line-height:1.8;font-style:italic;text-align:center;padding:15px;background:#87cefa1a;border-radius:10px}.word-input-section{margin:25px 0}.word-input-section label{display:block;color:#b0e0e6;font-size:1.1rem;margin-bottom:10px;font-weight:500}.word-input{width:100%;padding:15px 20px;font-size:1.3rem;background:#ffffff1a;border:3px solid rgba(135,206,250,.5);border-radius:15px;color:#fff;text-align:center;transition:all .3s ease}.word-input:focus{outline:none;border-color:gold;box-shadow:0 0 20px #ffd70080;background:#ffffff26}.word-input::placeholder{color:#ffffff80}.answer-display{margin:20px 0;padding:15px;background:#4caf5033;border:2px solid rgba(76,175,80,.5);border-radius:10px;text-align:center}.correct-answer{color:#4caf50;font-size:1.3rem}.correct-answer strong{color:gold;font-size:1.5rem}.word-actions{display:flex;gap:15px;justify-content:center;margin-top:25px}.action-button{padding:15px 35px;font-size:1.2rem;font-weight:600;color:#fff;border:none;border-radius:25px;cursor:pointer;transition:all .3s ease;min-width:150px}.check-button{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 5px 20px #4caf5066}.check-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px #4caf5099}.check-button:disabled{opacity:.5;cursor:not-allowed}.skip-button{background:linear-gradient(135deg,gold,orange);box-shadow:0 5px 20px #ffd70066}.skip-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #ffd70099}.next-button{background:linear-gradient(135deg,#1e90ff,#00bfff);box-shadow:0 5px 20px #1e90ff66}.next-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #1e90ff99}.word-stats{display:flex;gap:20px;justify-content:center;margin-top:20px}.stat-item{background:#1e90ff4d;padding:12px 25px;border-radius:15px;color:#e0f6ff;font-weight:600;font-size:1.1rem;border:2px solid rgba(135,206,250,.3)}.game-result{text-align:center;padding:50px 30px;border-radius:20px;margin:30px 0}.game-result.win{background:linear-gradient(135deg,#4caf504d,#388e3c4d);border:3px solid rgba(76,175,80,.6)}.game-result h2{color:gold;font-size:2.5rem;margin-bottom:20px;text-shadow:0 0 20px rgba(255,215,0,.8)}.game-result p{color:#e0f6ff;font-size:1.3rem;margin:10px 0;line-height:1.8}@media (max-width: 768px){.word-game-container{padding:25px;width:95%}.game-header h2,.meaning-text{font-size:1.5rem}.example-text{font-size:1rem}.word-input{font-size:1.1rem}.action-button{padding:12px 25px;font-size:1rem;min-width:120px}}.level-select-page{min-height:100vh;padding:40px 20px;position:relative;display:flex;align-items:center;justify-content:center}.level-select-content{position:relative;z-index:1;max-width:600px;width:100%;background:linear-gradient(135deg,#1e90ff26,#00448840);border-radius:30px;padding:50px 40px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(135,206,250,.3);box-shadow:0 20px 60px #0000004d,0 0 40px #87cefa33;text-align:center}.back-button{position:absolute;top:20px;left:20px;padding:10px 20px;font-size:1rem;color:#fff;background:#1e90ff4d;border:2px solid rgba(135,206,250,.5);border-radius:20px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.level-title{font-size:2.5rem;font-weight:700;margin-bottom:30px;color:gold;text-shadow:0 0 20px rgba(255,215,0,.8),0 2px 10px rgba(0,0,0,.5)}.character-preview{margin:40px 0}.character-icon{font-size:8rem;margin-bottom:20px;animation:float 4s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(255,255,255,.5))}.character-name{font-size:2rem;color:#e0f6ff;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.5)}.level-description{margin:30px 0;color:#b0e0e6;font-size:1.2rem;line-height:2}.start-level-button,.play-story-button{margin-top:30px;padding:18px 50px;font-size:1.3rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#1e90ff,#00bfff,#87ceeb);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #1e90ff66,0 0 20px #87cefa99}.start-level-button:hover,.play-story-button:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px #1e90ff99,0 0 30px #87cefacc}.level-completed{margin-top:30px;padding:20px;background:#4caf5033;border:2px solid rgba(76,175,80,.5);border-radius:15px}.level-completed p{color:#4caf50;font-size:1.3rem;font-weight:600;margin-bottom:20px}@media (max-width: 768px){.level-select-content{padding:30px 20px}.level-title{font-size:2rem}.character-icon{font-size:6rem}}.story-page{min-height:100vh;padding:40px 20px;position:relative;display:flex;align-items:center;justify-content:center}.story-content{position:relative;z-index:1;max-width:800px;width:100%;background:linear-gradient(135deg,#1e90ff26,#00448840);border-radius:30px;padding:50px 40px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(135,206,250,.3);box-shadow:0 20px 60px #0000004d,0 0 40px #87cefa33}.story-header{margin-bottom:40px}.back-to-graduation{padding:10px 20px;font-size:1rem;color:#fff;background:#1e90ff4d;border:2px solid rgba(135,206,250,.5);border-radius:20px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:20px}.back-to-graduation:hover{background:#1e90ff80;border-color:#87cefacc;transform:translate(-5px)}.story-progress{width:100%;height:8px;background:#fff3;border-radius:10px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#1e90ff,#00bfff,#87ceeb);border-radius:10px;transition:width .5s ease;box-shadow:0 0 10px #87cefa99}.story-body{text-align:center;margin:40px 0}.story-scene{font-size:8rem;margin-bottom:30px;animation:float 4s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(255,255,255,.5))}.story-page-title{font-size:2.5rem;font-weight:600;margin-bottom:30px;color:gold;text-shadow:0 0 20px rgba(255,215,0,.8),0 2px 10px rgba(0,0,0,.5)}.story-text{font-size:1.3rem;line-height:2;color:#e0f6ff;text-shadow:0 2px 10px rgba(0,0,0,.5);margin-bottom:40px}.story-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:50px;gap:20px}.nav-button{padding:15px 30px;font-size:1.1rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#1e90ff,#00bfff);border:none;border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 20px #1e90ff66;flex:1;max-width:200px}.nav-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px #1e90ff99}.nav-button:active:not(:disabled){transform:translateY(-1px)}.nav-button:disabled{opacity:.5;cursor:not-allowed}.next-button{background:linear-gradient(135deg,#ff6b9d,#ff8e9b);box-shadow:0 5px 20px #ff6b9d66}.next-button:hover:not(:disabled){box-shadow:0 8px 30px #ff6b9d99}.page-indicator{font-size:1.1rem;color:#b0e0e6;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,.5);min-width:80px;text-align:center}.story-1 .story-content{border-color:#ff6b9d80;box-shadow:0 20px 60px #0000004d,0 0 40px #ff6b9d4d}.story-2 .story-content{border-color:#4ecdc480;box-shadow:0 20px 60px #0000004d,0 0 40px #4ecdc44d}.story-3 .story-content{border-color:#ffe66d80;box-shadow:0 20px 60px #0000004d,0 0 40px #ffe66d4d}.story-4 .story-content{border-color:#95e1d380;box-shadow:0 20px 60px #0000004d,0 0 40px #95e1d34d}.story-5 .story-content{border-color:#ff475780;box-shadow:0 20px 60px #0000004d,0 0 40px #ff47574d}.story-6 .story-content{border-color:#ffa50280;box-shadow:0 20px 60px #0000004d,0 0 40px #ffa5024d}.story-7 .story-content{border-color:#5f27cd80;box-shadow:0 20px 60px #0000004d,0 0 40px #5f27cd4d}.story-user .story-content{border-color:var(--story-color);box-shadow:0 20px 60px #0000004d,0 0 40px var(--story-color)}@media (max-width: 768px){.story-content{padding:30px 20px}.story-scene{font-size:5rem}.story-page-title{font-size:2rem}.story-text{font-size:1.1rem}.story-navigation{flex-direction:column}.nav-button{width:100%;max-width:none}.page-indicator{order:-1}}.aquarium-page{min-height:100vh;padding:40px 20px;position:relative}.aquarium-content-wrapper{position:relative;z-index:100;width:100%;min-height:calc(100vh - 80px);display:block;visibility:visible;opacity:1}.aquarium-content{position:relative;z-index:101;max-width:1200px;margin:0 auto;width:100%;display:block;visibility:visible;opacity:1;background:transparent}.aquarium-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;flex-wrap:wrap;gap:20px;position:relative;z-index:200;width:100%}.aquarium-title{font-size:3rem;font-weight:700;color:gold!important;text-shadow:0 0 20px rgba(255,215,0,.8),0 2px 10px rgba(0,0,0,.5);margin:0;position:relative;z-index:102;display:block;visibility:visible;opacity:1}.back-button{padding:12px 30px!important;font-size:1.1rem!important;color:#fff!important;background:#1e90ffe6!important;border:2px solid rgba(135,206,250,1)!important;border-radius:25px!important;cursor:pointer!important;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative!important;z-index:200!important;white-space:nowrap;font-weight:600!important;box-shadow:0 5px 20px #1e90ff99!important;display:block!important;visibility:visible!important;opacity:1!important;pointer-events:auto!important;margin:0}.back-button:hover{background:#1e90ff80;border-color:#87cefacc;transform:translate(-5px)}.empty-aquarium{text-align:center;padding:100px 20px;background:linear-gradient(135deg,#1e90ff66,#00448880)!important;border-radius:30px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:3px solid rgba(135,206,250,.8)!important;box-shadow:0 20px 60px #00000080,0 0 40px #87cefa80;margin-top:40px;position:relative;z-index:102;display:block;visibility:visible;opacity:1}.empty-icon{font-size:8rem;margin-bottom:30px;animation:float 4s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(255,255,255,.5));display:block}.empty-text{font-size:2rem;color:gold!important;margin-bottom:20px;font-weight:600;text-shadow:0 0 20px rgba(255,215,0,.8);display:block;visibility:visible;opacity:1}.empty-hint{font-size:1.2rem;color:#e0f6ff!important;margin-bottom:40px;line-height:1.8;text-shadow:0 2px 10px rgba(0,0,0,.5);display:block;visibility:visible;opacity:1}.back-to-graduation-button{padding:15px 40px;font-size:1.2rem;color:#fff;background:linear-gradient(135deg,#1e90ff,#00bfff);border:none;border-radius:30px;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 20px #1e90ff66}.back-to-graduation-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #1e90ff99}.characters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:25px;margin-bottom:40px}.character-card{background:linear-gradient(135deg,#1e90ff33,#0044884d);border:3px solid var(--char-color);border-radius:20px;padding:30px;text-align:center;cursor:pointer;transition:all .4s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.character-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,var(--char-color) 0%,transparent 70%);opacity:0;transition:opacity .4s ease}.character-card:hover:before{opacity:.2}.character-card:hover{transform:translateY(-10px) scale(1.05);box-shadow:0 20px 40px #0000004d,0 0 30px var(--char-color)}.character-card.selected{border-color:gold;box-shadow:0 0 40px #ffd700cc,0 0 60px var(--char-color);transform:translateY(-5px) scale(1.02)}.character-emoji{font-size:5rem;margin-bottom:15px;filter:drop-shadow(0 0 20px rgba(255,255,255,.5));animation:float 4s ease-in-out infinite}.character-name{font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:10px;text-shadow:0 2px 10px rgba(0,0,0,.5)}.character-level{position:absolute;top:10px;right:10px;background:var(--char-color);color:#fff;padding:5px 12px;border-radius:15px;font-size:.9rem;font-weight:600;box-shadow:0 3px 10px #0000004d}.character-detail{background:linear-gradient(135deg,#1e90ff26,#00448840);border-radius:30px;padding:40px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(135,206,250,.3);box-shadow:0 20px 60px #0000004d,0 0 40px #87cefa33}.detail-header{display:flex;align-items:center;gap:30px;margin-bottom:30px}.detail-emoji{font-size:6rem;filter:drop-shadow(0 0 30px rgba(255,255,255,.5));animation:float 4s ease-in-out infinite}.detail-info h2{font-size:2.5rem;color:gold;margin-bottom:10px;text-shadow:0 0 20px rgba(255,215,0,.8)}.detail-description{font-size:1.2rem;color:#e0f6ff;line-height:1.8}.character-stats{background:#0000004d;border-radius:15px;padding:25px;margin-bottom:20px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1)}.stat-row:last-child{border-bottom:none}.stat-label{color:#b0e0e6;font-size:1.1rem}.stat-value{color:gold;font-size:1.2rem;font-weight:600}.exp-bar-container{width:100%;height:25px;background:#fff3;border-radius:15px;overflow:hidden;margin-bottom:30px}.exp-bar-fill{height:100%;background:linear-gradient(90deg,gold,orange);border-radius:15px;transition:width .5s ease;box-shadow:0 0 20px #ffd70099}.feed-section{text-align:center;margin-bottom:30px}.feed-button{padding:18px 50px;font-size:1.5rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#ff8e9b);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #ff6b9d66,0 0 20px #ff6b9d99;margin-bottom:15px}.feed-button:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px #ff6b9d99,0 0 30px #ff6b9dcc}.feed-message{font-size:1.2rem;margin:10px 0;padding:10px;border-radius:10px}.feed-message.success{color:#4caf50;background:#4caf5033}.feed-message.error{color:#ff4757;background:#ff475733}.feed-hint{color:#b0e0e6;font-size:1rem;margin-top:10px}.view-story-button{width:100%;padding:15px;font-size:1.2rem;color:#fff;background:linear-gradient(135deg,#1e90ff,#00bfff);border:none;border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 20px #1e90ff66}.view-story-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #1e90ff99}@media (max-width: 768px){.aquarium-title{font-size:2rem}.characters-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;text-align:center}.detail-emoji{font-size:4rem}}.report-page{min-height:100vh;padding:40px 20px;position:relative}.report-content{position:relative;z-index:100;max-width:900px;margin:0 auto;width:100%}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;flex-wrap:wrap;gap:20px}.report-title{font-size:2.5rem;font-weight:700;color:#ff4757;text-shadow:0 0 20px rgba(255,71,87,.8),0 2px 10px rgba(0,0,0,.5);margin:0}.back-button{padding:12px 30px;font-size:1.1rem;color:#fff;background:#1e90ffcc;border:2px solid rgba(135,206,250,1);border-radius:25px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600;box-shadow:0 5px 20px #1e90ff80}.report-form{background:linear-gradient(135deg,#1e90ff26,#00448840);border-radius:30px;padding:40px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(135,206,250,.3);box-shadow:0 20px 60px #0000004d,0 0 40px #87cefa33}.report-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}.report-type-card{background:#0000004d;border:2px solid rgba(135,206,250,.3);border-radius:15px;padding:25px;text-align:center;cursor:pointer;transition:all .3s ease}.report-type-card:hover{border-color:#87cefacc;transform:translateY(-5px);box-shadow:0 10px 30px #87cefa66}.report-type-card.selected{border-color:#ff4757;background:#ff475733;box-shadow:0 0 30px #ff475799,0 10px 30px #ff475766}.type-icon{font-size:3rem;margin-bottom:10px}.type-label{font-size:1.1rem;color:#fff;font-weight:500}.form-group textarea{resize:vertical;min-height:120px}.legal-section{background:#0003;border-radius:20px;padding:30px;border:2px solid rgba(255,215,0,.3)}.legal-articles{margin-bottom:25px}.legal-article{background:#0000004d;border-radius:15px;padding:20px;margin-bottom:20px;border-left:4px solid #FFD700}.legal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.law-name{color:gold;font-size:1.2rem;font-weight:600}.article-number{color:#87ceeb;font-size:1.1rem;font-weight:500;background:#87cefa33;padding:5px 15px;border-radius:10px}.legal-content{color:#e0f6ff;font-size:1rem;line-height:1.8;margin:0}.legal-notice{background:#ff475733;border:2px solid rgba(255,71,87,.5);border-radius:15px;padding:20px}.legal-notice p{color:gold;font-weight:600;font-size:1.1rem;margin-bottom:10px}.legal-notice ul{color:#e0f6ff;line-height:2;padding-left:25px;margin:0}.legal-notice li{margin-bottom:8px}.submit-button,.cancel-button{padding:15px 40px;font-size:1.2rem;font-weight:600;border:none;border-radius:25px;cursor:pointer;transition:all .3s ease}.submit-button{color:#fff;background:linear-gradient(135deg,#ff4757,#ff6b9d);box-shadow:0 10px 30px #ff475766,0 0 20px #ff475799}.submit-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #ff475799,0 0 30px #ff4757cc}.submit-success{background:linear-gradient(135deg,#4caf5033,#388e3c4d);border-radius:30px;padding:60px 40px;text-align:center;border:3px solid rgba(76,175,80,.6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.success-icon{font-size:5rem;margin-bottom:20px;animation:float 2s ease-in-out infinite}.submit-success h2{font-size:2.5rem;color:#4caf50;margin-bottom:20px;text-shadow:0 0 20px rgba(76,175,80,.8)}.submit-success p{font-size:1.2rem;color:#e0f6ff;margin-bottom:15px;line-height:1.8}.success-tip{color:gold!important;font-weight:600;font-size:1.3rem!important}.auto-redirect{color:#b0e0e6!important;font-size:1rem!important;margin-top:30px}@media (max-width: 768px){.report-title{font-size:2rem}.report-form{padding:25px}.report-types-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column}.submit-button,.cancel-button{width:100%}}.story-editor-page{min-height:100vh;padding:40px 20px;position:relative}.story-editor-content{position:relative;z-index:100;max-width:1000px;margin:0 auto;width:100%}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;flex-wrap:wrap;gap:20px}.editor-title{font-size:2.5rem;font-weight:700;color:gold;text-shadow:0 0 20px rgba(255,215,0,.8),0 2px 10px rgba(0,0,0,.5);margin:0}.back-button{padding:12px 30px;font-size:1.1rem;color:#fff;background:#1e90ffe6;border:2px solid rgba(135,206,250,1);border-radius:25px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600;box-shadow:0 5px 20px #1e90ff99}.back-button:hover{background:#1e90ff;transform:translate(-5px)}.editor-form{background:linear-gradient(135deg,#1e90ff26,#00448840);border-radius:30px;padding:40px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(135,206,250,.3);box-shadow:0 20px 60px #0000004d,0 0 40px #87cefa33}.form-section{margin-bottom:40px}.section-title{font-size:1.8rem;font-weight:600;color:gold;margin-bottom:25px;text-shadow:0 0 20px rgba(255,215,0,.6)}.form-group{margin-bottom:25px}.form-group label{display:block;color:#e0f6ff;font-size:1.1rem;font-weight:500;margin-bottom:10px}.form-group input,.form-group textarea{width:100%;padding:15px 20px;font-size:1rem;background:#ffffff1a;border:2px solid rgba(135,206,250,.5);border-radius:15px;color:#fff;transition:all .3s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:gold;box-shadow:0 0 20px #ffd70080;background:#ffffff26}.form-group input::placeholder,.form-group textarea::placeholder{color:#ffffff80}.color-options{display:flex;gap:15px;flex-wrap:wrap}.color-option{width:50px;height:50px;border-radius:50%;cursor:pointer;transition:all .3s ease;border:3px solid transparent}.color-option:hover{transform:scale(1.1);box-shadow:0 0 20px #ffffff80}.color-option.selected{border-color:gold;box-shadow:0 0 25px #ffd700cc,0 0 15px currentColor;transform:scale(1.15)}.pages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.add-page-button{padding:10px 25px;font-size:1rem;color:#fff;background:linear-gradient(135deg,#4ecdc4,#44a08d);border:none;border-radius:20px;cursor:pointer;transition:all .3s ease;font-weight:600;box-shadow:0 5px 20px #4ecdc466}.add-page-button:hover{transform:translateY(-3px);box-shadow:0 8px 30px #4ecdc499}.page-editor{background:#0003;border-radius:20px;padding:30px;margin-bottom:30px;border:2px solid rgba(135,206,250,.3)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-number{font-size:1.5rem;color:gold;margin:0;font-weight:600}.remove-page-button{padding:8px 20px;font-size:.9rem;color:#fff;background:#ff475780;border:2px solid rgba(255,71,87,.8);border-radius:15px;cursor:pointer;transition:all .3s ease}.remove-page-button:hover{background:#ff4757b3;transform:translateY(-2px)}.scene-selector{display:flex;gap:10px;flex-wrap:wrap}.scene-emoji{width:50px;height:50px;font-size:2rem;background:#ffffff1a;border:2px solid rgba(135,206,250,.5);border-radius:10px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.scene-emoji:hover{border-color:gold;transform:scale(1.1);background:#fff3}.scene-emoji.selected{border-color:gold;background:#ffd70033;box-shadow:0 0 20px #ffd70099;transform:scale(1.15)}.form-actions{display:flex;gap:20px;justify-content:center;margin-top:40px}.save-button,.cancel-button{padding:15px 40px;font-size:1.2rem;font-weight:600;border:none;border-radius:25px;cursor:pointer;transition:all .3s ease}.save-button{color:#fff;background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 10px 30px #4caf5066,0 0 20px #4caf5099}.save-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #4caf5099,0 0 30px #4caf50cc}.cancel-button{color:#fff;background:#64646480;border:2px solid rgba(255,255,255,.3)}.cancel-button:hover{background:#646464b3;transform:translateY(-3px)}@media (max-width: 768px){.editor-title{font-size:2rem}.editor-form{padding:25px}.form-actions{flex-direction:column}.save-button,.cancel-button{width:100%}}.q-font-title{font-family:"Press Start 2P",Courier New,monospace;font-weight:400;font-size:2.8rem;color:red;text-shadow:8px 8px 0px #000000,10px 10px 0px #000000,12px 12px 0px #000000,14px 14px 0px rgba(0,0,0,.8),6px 6px 0px #8B4513,4px 4px 0px #654321,2px 2px 0px #FFD700,1px 1px 0px #FFA500;letter-spacing:8px;line-height:1.3;image-rendering:pixelated;transform:rotate(-3deg) scale(1.15);position:relative;display:inline-block;animation:marioTitleBounce 1.2s ease-in-out infinite;filter:drop-shadow(4px 4px 0px #000000)}@keyframes marioTitleBounce{0%,to{transform:rotate(-2deg) scale(1.05) translateY(0)}50%{transform:rotate(-2deg) scale(1.05) translateY(-3px)}}.q-font-button{font-family:"Press Start 2P",Courier New,monospace;font-weight:400;font-size:.7rem;letter-spacing:1px;image-rendering:pixelated}.q-font-text{font-family:"Press Start 2P",Courier New,monospace;font-weight:400;font-size:.6rem;letter-spacing:.5px;line-height:1.8;image-rendering:pixelated}.gomoku-game{min-height:100vh;background:linear-gradient(135deg,#fff0f5,#f0fff0);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.background-sparkles{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.sparkle-bg{position:absolute;font-size:.8rem;line-height:1;-webkit-user-select:none;user-select:none;color:#fff9;text-shadow:0 0 5px rgba(255,255,255,.4);animation:sparkleFloatBg 4s ease-in-out infinite;background:#ffffff1a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:50%;padding:3px;box-shadow:0 1px 5px #0000000d,inset 0 1px #fff3}.sparkle-bg-1{top:5%;left:8%;color:#ffb6c1b3;animation-delay:0s}.sparkle-bg-2{top:12%;left:25%;color:#ffa500b3;animation-delay:.3s}.sparkle-bg-3{top:8%;left:45%;color:#87cefab3;animation-delay:.6s}.sparkle-bg-4{top:15%;left:65%;color:#90ee90b3;animation-delay:.9s}.sparkle-bg-5{top:6%;left:85%;color:#dda0ddb3;animation-delay:1.2s}.sparkle-bg-6{top:25%;left:5%;color:#ffc0cbb3;animation-delay:.2s}.sparkle-bg-7{top:30%;left:20%;color:#ffb6c1b3;animation-delay:.5s}.sparkle-bg-8{top:28%;left:40%;color:#ffffffb3;animation-delay:.8s}.sparkle-bg-9{top:32%;left:60%;color:#ffa500b3;animation-delay:1.1s}.sparkle-bg-10{top:26%;left:80%;color:#87cefab3;animation-delay:1.4s}.sparkle-bg-11{top:45%;left:10%;color:#90ee90b3;animation-delay:.1s}.sparkle-bg-12{top:50%;left:30%;color:#dda0ddb3;animation-delay:.4s}.sparkle-bg-13{top:48%;left:50%;color:#ffc0cbb3;animation-delay:.7s}.sparkle-bg-14{top:52%;left:70%;color:#ffb6c1b3;animation-delay:1s}.sparkle-bg-15{top:46%;left:90%;color:#ffffffb3;animation-delay:1.3s}.sparkle-bg-16{top:65%;left:15%;color:#ffa500b3;animation-delay:.2s}.sparkle-bg-17{top:70%;left:35%;color:#87cefab3;animation-delay:.5s}.sparkle-bg-18{top:68%;left:55%;color:#90ee90b3;animation-delay:.8s}.sparkle-bg-19{top:72%;left:75%;color:#dda0ddb3;animation-delay:1.1s}.sparkle-bg-20{top:66%;left:95%;color:#ffc0cbb3;animation-delay:1.4s}.sparkle-bg-21{top:85%;left:12%;color:#ffb6c1b3;animation-delay:.3s}.sparkle-bg-22{top:88%;left:32%;color:#ffffffb3;animation-delay:.6s}.sparkle-bg-23{top:86%;left:52%;color:#ffa500b3;animation-delay:.9s}.sparkle-bg-24{top:90%;left:72%;color:#87cefab3;animation-delay:1.2s}.sparkle-bg-25{top:84%;left:92%;color:#90ee90b3;animation-delay:1.5s}.sparkle-bg-26{top:18%;left:15%;color:#dda0ddb3;animation-delay:.1s}.sparkle-bg-27{top:38%;left:22%;color:#ffc0cbb3;animation-delay:.4s}.sparkle-bg-28{top:58%;left:18%;color:#ffb6c1b3;animation-delay:.7s}.sparkle-bg-29{top:78%;left:25%;color:#ffffffb3;animation-delay:1s}.sparkle-bg-30{top:22%;left:75%;color:#ffa500b3;animation-delay:1.3s}@keyframes sparkleFloatBg{0%,to{transform:translateY(0) scale(1) rotate(0);opacity:.5}50%{transform:translateY(-10px) scale(1.2) rotate(180deg);opacity:.9}}.gomoku-container{background:transparent;border:none;border-radius:0;padding:20px;max-width:800px;width:100%;box-shadow:none;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.game-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:15px;width:100%;max-width:450px}.game-header h1{margin:0}.header-buttons{display:flex;gap:10px;flex-wrap:wrap}.ai-generate-button{padding:8px 16px;font-size:.95rem;font-weight:400;color:#fff;background:#ffb6c1;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 5px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.ai-generate-button:hover{background:#ffa0b0;box-shadow:0 3px 8px #00000026}.ai-generate-button:active{transform:translateY(1px);box-shadow:0 1px 3px #0000001a}.ai-generate-button.active{background:#ff69b4;box-shadow:0 4px 15px #ff69b466,inset 0 1px #ffffff4d;border:2px solid rgba(255,255,255,.5)}.game-info{margin-bottom:15px;text-align:left;width:100%;max-width:450px}.current-player{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:400;color:#333;background:transparent;padding:0;border:none;border-radius:0;box-shadow:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.ai-turn-message{font-size:1.1rem;font-weight:600;color:#ff69b4;padding:8px 16px;background:linear-gradient(135deg,#ffb6c133,#98fb9833);border:2px solid rgba(255,182,193,.4);border-radius:20px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 8px #ffb6c133;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif}.player-indicator{width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:0;border-radius:0;border:none;flex-shrink:0}.player-indicator.black{background:#000}.player-indicator.white{background:#fff;border:1px solid #CCCCCC}.winner-message{padding:15px;background:#ffb6c1;border:none;border-radius:15px;box-shadow:0 2px 5px #0000001a;text-align:center;width:100%;max-width:450px}.winner-message h2{margin:0;font-size:1.2rem;color:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;text-shadow:none;animation:none}@keyframes marioBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.stars-decoration{display:flex;justify-content:center;align-items:center;gap:20px;margin:10px 0;width:100%;max-width:450px;position:relative;height:50px}.star{font-size:2.2rem;line-height:1;-webkit-user-select:none;user-select:none;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative;z-index:2;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:50%;padding:8px;box-shadow:0 4px 15px #0000001a,inset 0 1px #ffffff4d}.star-left,.star-right{color:plum;text-shadow:0 0 8px rgba(221,160,221,.6),0 0 15px rgba(221,160,221,.4),2px 2px 0px rgba(138,43,226,.3);filter:drop-shadow(0 0 3px rgba(221,160,221,.4))}.star-center{color:gold;text-shadow:0 0 8px rgba(255,215,0,.6),0 0 15px rgba(255,215,0,.4),2px 2px 0px rgba(255,140,0,.3);filter:drop-shadow(0 0 3px rgba(255,215,0,.4))}.sparkle{position:absolute;font-size:1rem;line-height:1;-webkit-user-select:none;user-select:none;color:#fffc;text-shadow:0 0 5px rgba(255,255,255,.5);animation:sparkleFloat 3s ease-in-out infinite;z-index:1;background:#ffffff26;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:50%;padding:4px;box-shadow:0 2px 8px #0000001a,inset 0 1px #fff3}.sparkle-1{top:-10px;left:10%;color:#ffb6c1e6;animation-delay:0s}.sparkle-2{top:5px;left:20%;color:#ffa500e6;animation-delay:.5s}.sparkle-3{top:-5px;left:30%;color:#87cefae6;animation-delay:1s}.sparkle-4{top:10px;left:40%;color:#90ee90e6;animation-delay:1.5s}.sparkle-5{top:-8px;left:50%;color:#dda0dde6;animation-delay:2s}.sparkle-6{top:8px;right:50%;color:#ffc0cbe6;animation-delay:.3s}.sparkle-7{top:-12px;right:30%;color:#ffb6c1e6;animation-delay:.8s}.sparkle-8{top:3px;right:15%;color:#ffffffe6;animation-delay:1.3s}@keyframes sparkleFloat{0%,to{transform:translateY(0) scale(1);opacity:.7}50%{transform:translateY(-8px) scale(1.1);opacity:1}}.board-container{display:flex;justify-content:center;margin:15px 0;overflow-x:auto;padding:0;background:transparent;border:none;border-radius:0;box-shadow:none;width:100%;max-width:450px}.gomoku-board{display:inline-block;background:#ecfcee99;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:0;border-radius:20px;box-shadow:0 0 0 3px #ffb6c14d,0 0 0 6px #ffb6c126,0 4px 15px #0000001a,inset 0 1px #ffffff4d,inset 0 -1px #0000000d;border:2px solid rgba(255,182,193,.4);position:relative;width:540px;height:540px;overflow:hidden}.gomoku-board:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:repeating-linear-gradient(to right,transparent 0,transparent 14.5px,#8B4513 14.5px,#8B4513 15.5px,transparent 15.5px,transparent 30px),repeating-linear-gradient(to bottom,transparent 0,transparent 17.5px,#8B4513 17.5px,#8B4513 18.5px,transparent 18.5px,transparent 36px);pointer-events:none;z-index:0;image-rendering:pixelated}.board-row{display:flex;position:relative;z-index:1;width:100%}.intersection{width:36px;height:36px;cursor:pointer;position:relative;box-sizing:border-box;display:block}.intersection:hover:before{display:none}.intersection.last-move:before{display:none}.stone{width:26px;height:26px;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;box-shadow:0 2px 4px #0003;transition:none;margin:0;border:2px solid #FFB6C1}.stone.black{background:#000;border:2px solid #FFB6C1}.stone.white{background:#fff;border:2px solid #FFB6C1}.stone.winning{box-shadow:0 0 15px gold,0 0 25px gold,0 0 35px gold,inset 0 0 10px #ffd7004d;border:2px solid #FFD700;animation:goldenGlow 1.5s ease-in-out infinite alternate}@keyframes goldenGlow{0%{box-shadow:0 0 10px gold,0 0 20px gold,0 0 30px gold,inset 0 0 8px #ffd7004d}to{box-shadow:0 0 20px gold,0 0 30px gold,0 0 40px gold,inset 0 0 12px #ffd70080}}.intersection:has(.stone):hover .stone{transform:translate(-50%,-50%)}.winning-line{position:absolute;top:0;left:0;pointer-events:none;z-index:3}.winning-line line{stroke:red;stroke-width:5;stroke-linecap:square;animation:drawLine .5s ease-out;filter:drop-shadow(2px 2px 0px #000000)}@keyframes drawLine{0%{stroke-dashoffset:1000}to{stroke-dashoffset:0}}.history-panel{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,182,193,.4);border-radius:25px;padding:25px;margin-bottom:25px;max-height:500px;overflow-y:auto;box-shadow:0 8px 32px #0000001a,inset 0 1px #fff9}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid rgba(255,182,193,.3)}.history-header h3{margin:0;font-size:1.4rem;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;background:linear-gradient(135deg,#ffb6c1,#98fb98);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:1px}.close-history{background:#ffb6c14d;border:2px solid rgba(255,182,193,.5);font-size:1.3rem;color:#ff69b4;cursor:pointer;padding:8px 12px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 8px #ffb6c14d;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif}.close-history:hover{background:#ffb6c180;transform:scale(1.1) rotate(90deg);box-shadow:0 4px 12px #ffb6c180;border-color:#ffb6c1cc}.no-history{text-align:center;background:linear-gradient(135deg,#ffb6c1,#98fb98);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding:40px 20px;font-size:1rem;font-weight:600}.history-list{display:flex;flex-direction:column;gap:12px}.history-list-header{display:flex;align-items:center;gap:15px;padding:10px 15px;margin-bottom:10px;font-weight:600;color:#333;font-size:.9rem;border-bottom:1px solid rgba(0,0,0,.1)}.history-list-checkbox,.history-list-date,.history-list-winner{flex:0 0 auto}.history-list-date{flex:1}.history-list-winner{text-align:right}.history-item{display:flex;flex-direction:column;background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(255,182,193,.3);border-radius:20px;padding:18px 20px;margin-bottom:12px;transition:all .3s ease;box-shadow:0 2px 8px #0000000d}.history-item:hover{background:#ffffffe6;border-color:#ffb6c180;transform:translateY(-2px);box-shadow:0 4px 16px #ffb6c133}.history-item-radio{width:16px;height:16px;border:2px solid rgba(0,0,0,.3);border-radius:50%;display:inline-block;flex-shrink:0;text-align:center;line-height:12px;font-size:12px;color:#0000004d}.history-date{flex:1;background:linear-gradient(135deg,#ffb6c1,pink,#ffb6c1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600;font-size:.95rem}.history-winner{font-weight:700;padding:6px 16px;border-radius:20px;font-size:.9rem;flex:0 0 auto;text-align:center;white-space:nowrap;box-shadow:0 2px 8px #0000001a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.history-winner.player-win{background:linear-gradient(135deg,#ffb6c166,#ffc0cb66);border:2px solid rgba(255,182,193,.6);color:#ff69b4;box-shadow:0 2px 8px #ffb6c14d}.history-winner.ai-win{background:linear-gradient(135deg,#98fb9866,#90ee9066);border:2px solid rgba(152,251,152,.6);color:#32cd32;box-shadow:0 2px 8px #98fb984d}.history-item-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:10px}.history-item-details{display:flex;gap:15px;flex-wrap:wrap;font-size:.85rem;color:#666c}.clear-history-button{margin-top:20px;width:100%;padding:14px;background:linear-gradient(135deg,#ffb6c14d,#98fb984d);border:2px solid rgba(255,182,193,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#ff69b4;border-radius:20px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #ffb6c133;cursor:pointer}.clear-history-button:hover{background:linear-gradient(135deg,#ffb6c180,#98fb9880);border-color:#ffb6c1cc;transform:translateY(-2px);box-shadow:0 4px 16px #ffb6c14d}.game-rules{background:#fff;padding:20px;border-radius:0;margin-top:25px;border:4px solid #000000;box-shadow:6px 6px #000}.game-rules h3{color:#00f;margin-top:0;margin-bottom:15px;font-size:.9rem;font-weight:400;text-shadow:2px 2px 0px #000000}.game-rules ul{margin:0;padding-left:20px;color:#333;line-height:2;font-size:.6rem}.game-rules li{margin-bottom:8px}.history-panel::-webkit-scrollbar{width:10px}.history-panel::-webkit-scrollbar-track{background:#ffb6c11a;border-radius:10px}.history-panel::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#ffb6c199,#98fb9899);border-radius:10px;border:2px solid rgba(255,255,255,.3)}.history-panel::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#ffb6c1cc,#98fb98cc)}@media (max-width: 768px){.gomoku-container{padding:20px}.q-font-title{font-size:1.2rem}.game-header{flex-direction:column;gap:15px;align-items:flex-start}.header-buttons{width:100%;justify-content:space-between}.gomoku-board{width:375px;height:375px}.gomoku-board:before{background-image:repeating-linear-gradient(to right,transparent 0,transparent 11.5px,#8B4513 11.5px,#8B4513 12.5px,transparent 12.5px,transparent 25px),repeating-linear-gradient(to bottom,transparent 0,transparent 11.5px,#8B4513 11.5px,#8B4513 12.5px,transparent 12.5px,transparent 25px)}.intersection{width:25px;height:25px}.stone{width:20px;height:20px}.history-item-details{flex-direction:column;gap:5px}}@media (max-width: 480px){.gomoku-board{width:300px;height:300px}.gomoku-board:before{background-image:repeating-linear-gradient(to right,transparent 0,transparent 9px,#8B4513 9px,#8B4513 10px,transparent 10px,transparent 20px),repeating-linear-gradient(to bottom,transparent 0,transparent 9px,#8B4513 9px,#8B4513 10px,transparent 10px,transparent 20px)}.intersection{width:20px;height:20px}.stone{width:18px;height:18px}}.game-footer{margin-top:15px;width:100%;max-width:450px}.footer-bar{display:flex;justify-content:space-between;align-items:center;background:transparent;border-radius:15px;padding:15px 20px;margin-bottom:15px}.piece-indicators{display:flex;gap:8px}.piece-indicator{width:20px;height:20px;border-radius:50%;border:2px solid #FFB6C1}.piece-indicator.white{background:#fff}.piece-indicator.black{background:#000}.footer-icons{display:flex;gap:10px;align-items:center}.footer-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#000}.footer-icon.plus{color:#87ceeb;font-weight:700}.footer-icon.circle{border:2px solid #000000;border-radius:50%;background:transparent;width:24px;height:24px;position:relative}.footer-icon.circle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border:2px solid #000000;border-radius:50%}.footer-buttons{display:flex;gap:10px;width:100%}.start-button,.settings-button{padding:8px 24px;font-size:1rem;font-weight:400;color:#fff;background:#ffb6c14d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.5);border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a,inset 0 1px #ffffff4d,inset 0 -1px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;flex:1;margin:0 8px;position:relative;overflow:hidden}.start-button:before,.settings-button:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.4) 0%,transparent 100%);pointer-events:none;border-radius:25px 25px 0 0}.start-button:hover,.settings-button:hover{background:#ffb6c166;box-shadow:0 6px 20px #00000026,inset 0 1px #fff6,inset 0 -1px #0000001a;transform:translateY(-2px);border-color:#ffffffb3}.start-button:active,.settings-button:active{transform:translateY(0);box-shadow:0 2px 10px #0000001a,inset 0 1px #fff3}.start-button.active{background:#ffb6c180;border-color:#fffc;box-shadow:0 6px 20px #ffb6c14d,inset 0 1px #ffffff80,inset 0 -1px #0000001a}.skill-panel{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,182,193,.5);border-radius:20px;padding:20px;margin-bottom:25px;max-height:500px;overflow-y:auto;box-shadow:0 8px 25px #00000026,inset 0 1px #ffffff80;z-index:100}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:2px solid rgba(255,182,193,.3)}.skill-header h3{margin:0;font-size:1.2rem;color:#333;font-weight:700}.close-skill{background:#ffb6c14d;border:2px solid rgba(255,255,255,.5);font-size:1.2rem;color:#666;cursor:pointer;padding:5px 12px;border-radius:15px;transition:all .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.close-skill:hover{background:#ffb6c180;transform:scale(1.1)}.skill-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.skill-button{background:#ffb6c133;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.5);border-radius:15px;padding:15px;cursor:pointer;transition:all .3s ease;text-align:left;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff4d}.skill-button:hover:not(:disabled){background:#ffb6c159;transform:translateY(-2px);box-shadow:0 4px 12px #00000026,inset 0 1px #fff6;border-color:#ffffffb3}.skill-button:disabled{opacity:.5;cursor:not-allowed;background:#c8c8c833}.skill-button.used{position:relative}.skill-button.used:after{content:"已使用";position:absolute;top:5px;right:5px;background:#f00c;color:#fff;font-size:.6rem;padding:2px 6px;border-radius:8px}.skill-name{font-size:1rem;font-weight:700;color:#333;margin-bottom:8px}.skill-panel-footer{margin-top:20px;padding-top:15px;border-top:2px solid rgba(255,182,193,.3);display:flex;justify-content:center}.skill-return-button{background:#ffb6c14d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.5);border-radius:25px;padding:12px 40px;color:#333;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a,inset 0 1px #ffffff4d,inset 0 -1px #0000001a;position:relative;overflow:hidden}.skill-return-button:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.4) 0%,transparent 100%);pointer-events:none;border-radius:25px 25px 0 0}.skill-return-button:hover{background:#ffb6c166;transform:translateY(-2px);box-shadow:0 6px 20px #00000026,inset 0 1px #fff6,inset 0 -1px #0000001a;border-color:#ffffffb3}.skill-return-button:active{transform:translateY(0);box-shadow:0 2px 10px #0000001a,inset 0 1px #fff3}.skill-name{font-size:1rem;font-weight:700;color:#333;margin-bottom:5px}.skill-desc{font-size:.85rem;color:#666;line-height:1.4}.intersection.skill-target{position:relative;cursor:pointer}.intersection.skill-target:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% + 4px);height:calc(100% + 4px);border:3px solid #FF69B4;border-radius:50%;box-shadow:0 0 10px #ff69b499,inset 0 0 10px #ff69b44d;animation:skillTargetPulse 1.5s ease-in-out infinite;pointer-events:none;z-index:10}@keyframes skillTargetPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.1);opacity:.7}}.skill-hint{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,182,193,.5);border-radius:20px;padding:20px 30px;box-shadow:0 8px 25px #0003,inset 0 1px #ffffff80;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:15px;position:relative}.skill-hint>div{font-size:1.1rem;color:#333;font-weight:700}.cancel-skill{position:absolute;top:10px;right:10px;background:#ffffffe6;border:2px solid rgba(255,182,193,.5);border-radius:50%;width:32px;height:32px;padding:0;cursor:pointer;transition:all .3s ease;color:#666;font-size:1.2rem;display:flex;align-items:center;justify-content:center;line-height:1}.cancel-skill:hover{background:#ffb6c180;transform:scale(1.1);border-color:#ffb6c1cc}.victory-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:2000}.victory-modal{background:linear-gradient(180deg,#fff0f5fa,#fffffffa);border-radius:20px;padding:0;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d,inset 0 1px #ffffff80;position:relative;overflow:hidden}.victory-modal-header{background:#fff0f599;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;position:relative;border-bottom:1px solid rgba(255,182,193,.3)}.victory-stars{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:10px}.victory-star{font-size:1.5rem;color:gold;text-shadow:0 0 10px rgba(255,215,0,.8);animation:starTwinkle 2s ease-in-out infinite}.victory-star:nth-child(1){animation-delay:0s}.victory-star:nth-child(2){animation-delay:.2s}.victory-star:nth-child(3){animation-delay:.4s}.victory-star:nth-child(4){animation-delay:.6s}.victory-star:nth-child(5){animation-delay:.8s}.victory-star-large{font-size:2.5rem}.victory-close{position:absolute;top:15px;right:15px;background:#ffffffe6;border:2px solid rgba(255,182,193,.5);border-radius:50%;width:32px;height:32px;cursor:pointer;transition:all .3s ease;color:#666;font-size:1.2rem;display:flex;align-items:center;justify-content:center;line-height:1}.victory-close:hover{background:#ffb6c180;transform:scale(1.1);border-color:#ffb6c1cc}.victory-modal-content{padding:40px 20px;text-align:center}.victory-title{font-size:2.5rem;font-weight:700;color:#dc143c;margin:0;text-shadow:0 2px 10px rgba(220,20,60,.3)}.victory-subtitle{font-size:1.2rem;color:#666;margin-top:10px;font-weight:400}.victory-modal-buttons{display:flex;gap:15px;padding:0 20px 30px;justify-content:center}.victory-button{flex:1;padding:12px 24px;background:#ffb6c14d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.5);border-radius:25px;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a,inset 0 1px #ffffff4d,inset 0 -1px #0000001a;position:relative;overflow:hidden}.victory-button:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.4) 0%,transparent 100%);pointer-events:none;border-radius:25px 25px 0 0}.victory-button:hover{background:#ffb6c166;transform:translateY(-2px);box-shadow:0 6px 20px #00000026,inset 0 1px #fff6,inset 0 -1px #0000001a;border-color:#ffffffb3}.victory-button:active{transform:translateY(0);box-shadow:0 2px 10px #0000001a,inset 0 1px #fff3}@keyframes starTwinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.ai-skill-effect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;pointer-events:none;z-index:100;display:flex;align-items:center;justify-content:center}.skill-vortex{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.8) 0%,rgba(255,215,0,.4) 30%,transparent 70%);animation:vortexSpin 1.5s linear infinite;filter:blur(3px)}.skill-particles{position:absolute;width:120%;height:120%;border-radius:50%;background:radial-gradient(circle,rgba(139,69,19,.6) 0%,rgba(139,69,19,.3) 40%,transparent 70%);animation:particlesFloat 1.5s ease-in-out infinite;filter:blur(2px)}.skill-text{position:relative;z-index:10;font-size:1.2rem;font-weight:700;color:gold;text-shadow:0 0 10px rgba(255,215,0,1),0 0 20px rgba(255,215,0,.8),0 2px 5px rgba(0,0,0,.5);animation:textPulse 1.5s ease-in-out infinite;text-align:center;white-space:nowrap}.player-skill-effect-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:150;display:flex;align-items:center;justify-content:center}.skill-canvas-container{position:relative;width:450px;height:450px;display:flex;align-items:center;justify-content:center}.skill-canvas{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 30px rgba(0,0,0,.3))}.skill-name-display{position:absolute;bottom:10%;left:50%;transform:translate(-50%);font-size:3rem;font-weight:900;background:linear-gradient(135deg,gold,orange,tomato);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,165,0,.6),0 4px 8px rgba(0,0,0,.4);z-index:10;animation:skillNameAppear 1s cubic-bezier(.34,1.56,.64,1) forwards;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;letter-spacing:6px;white-space:nowrap;padding:20px 40px;border-radius:25px;box-shadow:0 10px 40px #ffd70066,0 0 60px #ffa5004d,inset 0 2px 10px #fff9,inset 0 -2px 10px #0003;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:3px solid rgba(255,215,0,.5);background-color:#fffffff2;position:relative;overflow:hidden}.skill-name-display:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);animation:skillNameShine 2s ease-in-out infinite;pointer-events:none}@keyframes skillNameAppear{0%{opacity:0;transform:translate(-50%) scale(.3) rotate(-10deg);filter:blur(10px)}40%{transform:translate(-50%) scale(1.15) rotate(5deg);filter:blur(2px)}60%{transform:translate(-50%) scale(.95) rotate(-2deg)}80%{transform:translate(-50%) scale(1.05) rotate(1deg)}to{opacity:1;transform:translate(-50%) scale(1) rotate(0);filter:blur(0px)}}@keyframes skillNameShine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}.gacha-anim-container{position:relative;width:400px;height:400px;display:flex;align-items:center;justify-content:center}.gacha-pink-bg{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,#ffe4e1,#ffb6c1);border-radius:50%;opacity:.95;animation:gachaBgFadeIn .5s ease-out forwards}.gacha-grass-circle{position:absolute;width:320px;height:320px;background:radial-gradient(circle,#90ee90,#7cfc00,#32cd32);border-radius:50%;box-shadow:0 10px 30px #0003,inset 0 2px 10px #ffffff4d;animation:gachaGrassAppear .6s ease-out .2s forwards;opacity:0;transform:scale(.8);background-image:radial-gradient(circle at 20% 30%,rgba(144,238,144,.8) 2px,transparent 2px),radial-gradient(circle at 60% 50%,rgba(124,252,0,.7) 1.5px,transparent 1.5px),radial-gradient(circle at 80% 70%,rgba(144,238,144,.8) 2px,transparent 2px),radial-gradient(circle at 40% 20%,rgba(124,252,0,.6) 1px,transparent 1px),radial-gradient(circle at 70% 60%,rgba(144,238,144,.7) 1.5px,transparent 1.5px);background-size:30px 30px,25px 25px,35px 35px,20px 20px,28px 28px;background-position:0% 0%,20% 20%,40% 40%,60% 60%,80% 80%}.gacha-card-pack{position:absolute;width:200px;height:140px;z-index:10;animation:gachaPackAppear .8s ease-out .4s forwards;opacity:0;transform:translateY(20px)}.gacha-pack-left,.gacha-pack-right{position:absolute;width:50%;height:100%;background:linear-gradient(135deg,#e6e6fa,plum,#ba55d3);border-radius:12px;box-shadow:0 4px 15px #0003,inset 0 1px #fff6,inset 0 -1px #0000001a;border:3px solid #9370DB;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative}.gacha-pack-left:before,.gacha-pack-right:before{content:"";position:absolute;top:10px;left:10px;right:10px;bottom:10px;border:2px solid rgba(255,255,255,.3);border-radius:8px;pointer-events:none}.gacha-pack-left{left:0;border-radius:12px 0 0 12px;transform-origin:right center;animation:gachaPackOpenLeft 1s ease-out 1.2s forwards}.gacha-pack-right{right:0;border-radius:0 12px 12px 0;transform-origin:left center;animation:gachaPackOpenRight 1s ease-out 1.2s forwards}.gacha-golden-card{position:absolute;width:120px;height:160px;z-index:15;animation:gachaCardAppear 1.2s ease-out 1.5s forwards;opacity:0;transform:translateY(30px) scale(.8)}.gacha-card-back{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,gold,orange,gold 60%,orange);border-radius:12px;box-shadow:0 8px 25px #ffd70099,0 0 40px #ffd70066,inset 0 2px 5px #ffffff80,inset 0 -2px 5px #0003;border:3px solid #FF8C00;background-image:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,255,255,.15) 8px,rgba(255,255,255,.15) 16px),radial-gradient(circle at 30% 30%,rgba(255,255,255,.4) 0%,transparent 60%),radial-gradient(circle at 70% 70%,rgba(255,140,0,.3) 0%,transparent 50%);filter:brightness(1.1) contrast(1.1)}.gacha-card-front{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,gold,orange,gold 60%,orange);border-radius:12px;display:flex;align-items:center;justify-content:center;transform:rotateY(180deg);backface-visibility:hidden;animation:gachaCardFlip .8s ease-out 2.2s forwards;box-shadow:0 8px 25px #ffd70099,0 0 40px #ffd70066,inset 0 2px 5px #ffffff80,inset 0 -2px 5px #0003;border:3px solid #FF8C00;background-image:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,255,255,.15) 8px,rgba(255,255,255,.15) 16px),radial-gradient(circle at 30% 30%,rgba(255,255,255,.4) 0%,transparent 60%);filter:brightness(1.1) contrast(1.1)}.gacha-card-character{width:90px;height:90px;background:radial-gradient(circle,gold,orange,#ff8c00);border-radius:50%;border:4px solid #FF8C00;box-shadow:0 0 25px gold,0 0 50px #ffd70099,inset 0 0 25px #fff6,inset 0 -5px 10px #0000004d;position:relative;animation:gachaCharacterGlow 2s ease-in-out infinite}.gacha-card-character:before{content:"★";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3.5rem;color:#ff8c00;text-shadow:0 0 15px rgba(255,140,0,1),0 0 30px rgba(255,215,0,.8),2px 2px 4px rgba(0,0,0,.5);animation:gachaStarSpin 3s linear infinite}@keyframes gachaCharacterGlow{0%,to{box-shadow:0 0 25px gold,0 0 50px #ffd70099,inset 0 0 25px #fff6}50%{box-shadow:0 0 35px gold,0 0 70px #ffd700cc,inset 0 0 30px #ffffff80}}@keyframes gachaStarSpin{0%{transform:translate(-50%,-50%) rotate(0) scale(1)}50%{transform:translate(-50%,-50%) rotate(180deg) scale(1.1)}to{transform:translate(-50%,-50%) rotate(360deg) scale(1)}}.gacha-star{position:absolute;font-size:2.2rem;line-height:1;animation:gachaStarFloat 2s ease-in-out infinite;z-index:5;background:#fff3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:50%;padding:5px;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff4d}.gacha-star-1{top:15%;left:20%;color:#ffb6c1;animation-delay:0s}.gacha-star-2{top:10%;right:25%;color:#ffa07a;animation-delay:.3s}.gacha-star-3{top:25%;left:10%;color:#87ceeb;animation-delay:.6s}.gacha-star-4{bottom:20%;left:15%;color:#ffb6c1;animation-delay:.9s}.gacha-star-5{bottom:15%;right:20%;color:#ffa07a;animation-delay:1.2s}.gacha-star-6{top:50%;left:5%;color:silver;text-shadow:0 0 10px rgba(192,192,192,.8),0 0 20px rgba(255,255,255,.6);animation-delay:1.5s;background:linear-gradient(135deg,#ffffff4d,#c0c0c033)}.gacha-star-7{top:45%;right:8%;color:silver;text-shadow:0 0 10px rgba(192,192,192,.8),0 0 20px rgba(255,255,255,.6);animation-delay:1.8s;background:linear-gradient(135deg,#ffffff4d,#c0c0c033)}.gacha-moon{position:absolute;bottom:20%;right:15%;font-size:2.8rem;z-index:5;animation:gachaMoonFloat 2.5s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,255,0,.8));background:#ff03;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:50%;padding:8px;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff4d}.gacha-glow{position:absolute;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(221,160,221,.4) 0%,rgba(186,85,211,.2) 50%,transparent 100%);animation:gachaGlowPulse 2s ease-in-out infinite;z-index:1}.gacha-colorful-effects{position:absolute;width:100%;height:100%;z-index:2}.gacha-effect-1,.gacha-effect-2,.gacha-effect-3{position:absolute;width:60px;height:60px;border-radius:50%;filter:blur(15px);animation:gachaEffectFloat 3s ease-in-out infinite}.gacha-effect-1{background:radial-gradient(circle,rgba(255,182,193,.6) 0%,transparent 70%);top:20%;left:30%;animation-delay:0s}.gacha-effect-2{background:radial-gradient(circle,rgba(135,206,235,.6) 0%,transparent 70%);top:60%;right:25%;animation-delay:1s}.gacha-effect-3{background:radial-gradient(circle,rgba(255,215,0,.6) 0%,transparent 70%);bottom:25%;left:50%;animation-delay:2s}.gacha-ssr-text{position:absolute;top:8%;left:50%;transform:translate(-50%);font-size:3.5rem;font-weight:700;color:gold;text-shadow:0 0 25px rgba(255,215,0,1),0 0 50px rgba(255,215,0,.9),0 0 75px rgba(255,215,0,.6),3px 3px 6px rgba(0,0,0,.6);z-index:20;animation:gachaSSRPop .8s ease-out 2.5s forwards;opacity:0;transform:translate(-50%) scale(0);letter-spacing:10px;font-family:Arial,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#ffd7004d,#ff8c0033);padding:10px 20px;border-radius:15px;border:2px solid rgba(255,215,0,.5);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.gacha-skill-name{position:absolute;bottom:12%;left:50%;transform:translate(-50%);font-size:2.5rem;font-weight:700;color:#8b4513;text-shadow:2px 2px 0px #654321,4px 4px 0px rgba(0,0,0,.5),0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,215,0,.4);z-index:20;animation:gachaSkillNamePop .8s ease-out 3s forwards;opacity:0;transform:translate(-50%) translateY(20px);white-space:nowrap;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;letter-spacing:6px;background:linear-gradient(135deg,#fff0f5e6,#ffffffe6);padding:12px 30px;border-radius:20px;border:3px solid rgba(221,160,221,.6);box-shadow:0 4px 15px #0003,inset 0 1px #ffffff80;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@keyframes gachaBgFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:.95;transform:scale(1)}}@keyframes gachaGrassAppear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes gachaPackAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes gachaPackOpenLeft{0%{transform:rotateY(0)}to{transform:rotateY(-45deg)}}@keyframes gachaPackOpenRight{0%{transform:rotateY(0)}to{transform:rotateY(45deg)}}@keyframes gachaCardAppear{0%{opacity:0;transform:translateY(30px) scale(.8) rotateY(0)}50%{opacity:1;transform:translateY(-10px) scale(1.05) rotateY(90deg)}to{opacity:1;transform:translateY(0) scale(1) rotateY(0)}}@keyframes gachaCardFlip{0%{transform:rotateY(180deg)}to{transform:rotateY(0)}}@keyframes gachaStarFloat{0%,to{transform:translateY(0) rotate(0) scale(1);opacity:.8}50%{transform:translateY(-10px) rotate(180deg) scale(1.2);opacity:1}}@keyframes gachaMoonFloat{0%,to{transform:translateY(0) rotate(0);opacity:.9}50%{transform:translateY(-8px) rotate(15deg);opacity:1}}@keyframes gachaGlowPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}@keyframes gachaEffectFloat{0%,to{transform:translate(0) scale(1);opacity:.6}33%{transform:translate(20px,-20px) scale(1.2);opacity:.8}66%{transform:translate(-15px,15px) scale(.9);opacity:.7}}@keyframes gachaSSRPop{0%{opacity:0;transform:translate(-50%) scale(0) rotate(-10deg)}50%{transform:translate(-50%) scale(1.2) rotate(5deg)}to{opacity:1;transform:translate(-50%) scale(1) rotate(0)}}@keyframes gachaSkillNamePop{0%{opacity:0;transform:translate(-50%) translateY(20px) scale(.8)}50%{transform:translate(-50%) translateY(-5px) scale(1.1)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.player-skill-vortex{position:absolute;width:100%;height:100%;border-radius:50%;background:conic-gradient(from 0deg,transparent 0deg,rgba(255,215,0,.8) 30deg,transparent 60deg,rgba(255,200,0,.7) 90deg,transparent 120deg,rgba(255,215,0,.6) 150deg,transparent 180deg,rgba(255,180,0,.7) 210deg,transparent 240deg,rgba(255,215,0,.5) 270deg,transparent 300deg,rgba(255,200,0,.6) 330deg,transparent 360deg);animation:playerSkillVortexSpin 2s linear infinite;transform-origin:center;filter:blur(2px);opacity:.9}.feisha-effect .player-skill-vortex{animation:feishaVortexExpand 2s ease-in-out forwards}.player-skill-dust{position:absolute;width:140%;height:140%;border-radius:50%;background:radial-gradient(circle at 15% 25%,rgba(210,180,140,.6) 3px,transparent 3px),radial-gradient(circle at 35% 45%,rgba(222,184,135,.5) 2px,transparent 2px),radial-gradient(circle at 55% 30%,rgba(210,180,140,.6) 2.5px,transparent 2.5px),radial-gradient(circle at 75% 50%,rgba(222,184,135,.5) 2px,transparent 2px),radial-gradient(circle at 25% 65%,rgba(210,180,140,.6) 3px,transparent 3px),radial-gradient(circle at 65% 75%,rgba(222,184,135,.5) 2px,transparent 2px),radial-gradient(circle at 45% 15%,rgba(210,180,140,.4) 1.5px,transparent 1.5px),radial-gradient(circle at 85% 35%,rgba(222,184,135,.5) 2px,transparent 2px);background-size:40px 40px,35px 35px,45px 45px,30px 30px,38px 38px,42px 42px,25px 25px,40px 40px;background-position:0% 0%,20% 20%,40% 40%,60% 60%,80% 80%,100% 100%,15% 15%,85% 85%;animation:playerSkillDustFloat 3s ease-in-out infinite;filter:blur(1px);opacity:.9;z-index:1}.feisha-effect .player-skill-dust{animation:feishaDustExpand 2s ease-in-out forwards}.player-skill-text{position:absolute;z-index:20;font-size:1.8rem;font-weight:700;color:#8b4513;text-shadow:2px 2px 0px #654321,4px 4px 0px rgba(0,0,0,.4),0 0 8px rgba(255,215,0,.4);animation:playerSkillTextPop .6s ease-out forwards;text-align:center;white-space:nowrap;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;letter-spacing:3px;transform:scale(0);opacity:0;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);margin-top:60px}.feisha-effect .player-skill-text{font-size:1.5rem;color:#000;text-shadow:1px 1px 2px rgba(255,255,255,.8),2px 2px 4px rgba(0,0,0,.3);margin-top:0;animation:feishaTextFadeIn 2s ease-out forwards;letter-spacing:2px}@keyframes playerSkillVortexSpin{0%{transform:rotate(0) scale(1);opacity:.9}to{transform:rotate(360deg) scale(1);opacity:.9}}@keyframes feishaVortexExpand{0%{transform:scale(0) rotate(0);opacity:1}50%{transform:scale(1) rotate(180deg);opacity:1}to{transform:scale(0) rotate(360deg);opacity:0}}@keyframes feishaDustExpand{0%{transform:scale(0);opacity:1}50%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:0}}@keyframes feishaTextFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}25%{opacity:.5;transform:translate(-50%,-50%) scale(.95)}50%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes playerSkillDustFloat{0%,to{transform:translate(0) rotate(0);opacity:.6}25%{transform:translate(-10px,-10px) rotate(90deg);opacity:.8}50%{transform:translate(10px,-5px) rotate(180deg);opacity:1}75%{transform:translate(-5px,10px) rotate(270deg);opacity:.8}}@keyframes playerSkillTextPop{0%{transform:translate(-50%,-50%) scale(0) rotate(-10deg);opacity:0}50%{transform:translate(-50%,-50%) scale(1.15) rotate(5deg);opacity:1}to{transform:translate(-50%,-50%) scale(1) rotate(0);opacity:1}}@keyframes vortexSpin{0%{transform:rotate(0) scale(1)}to{transform:rotate(360deg) scale(1.1)}}@keyframes particlesFloat{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:.6}}@keyframes textPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.ai-chat-top-right{position:fixed;top:20px;right:20px;display:flex;align-items:flex-start;gap:12px;z-index:1000;max-width:calc(100vw - 40px)}.ai-avatar-with-wreath{position:relative;flex-shrink:0}.ai-avatar-circle{width:70px;height:70px;border-radius:50%;border:3px solid #fff;object-fit:cover;position:relative;z-index:2;box-shadow:0 4px 12px #00000026}.christmas-wreath{position:absolute;top:-8px;left:-8px;width:86px;height:86px;z-index:1;pointer-events:none}.wreath-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:6px solid #228B22;border-radius:50%;box-shadow:inset 0 0 10px #228b224d,0 0 15px #228b2233}.wreath-berries{position:absolute;top:5px;right:8px;width:12px;height:12px;background:#dc143c;border-radius:50%;box-shadow:0 0 8px #dc143c99,25px 15px 0 -3px #dc143c,15px 25px 0 -3px #dc143c,-10px 20px 0 -3px #dc143c}.wreath-bells{position:absolute;bottom:8px;left:10px;width:10px;height:12px;background:gold;border-radius:50%/60% 60% 40% 40%;box-shadow:0 0 6px #ffd70099,20px -15px 0 -2px gold}.ai-speech-bubble{position:relative;max-width:280px;min-width:120px;animation:bubbleAppear .4s ease-out}@keyframes bubbleAppear{0%{opacity:0;transform:translate(10px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.speech-bubble-content{background:#fff8dc;border:2px dashed #8B4513;border-radius:16px;padding:12px 16px;position:relative;box-shadow:0 4px 12px #0000001a}.speech-bubble-text{font-size:.95rem;line-height:1.6;color:#654321;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;word-wrap:break-word;word-break:break-word;font-weight:500}.typing-indicator{font-size:.9rem;color:#8b7355;font-style:italic;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif}.speech-bubble-decoration{position:absolute;bottom:-8px;right:8px;display:flex;gap:4px;font-size:.7rem;z-index:1}.speech-bubble-decoration .berry{display:inline-block;animation:berryBounce 2s ease-in-out infinite}.speech-bubble-decoration .holly{display:inline-block;animation:hollySway 2.5s ease-in-out infinite}@keyframes berryBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.1)}}@keyframes hollySway{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.chat-input-area-bottom{display:flex;gap:10px;padding:15px 20px;margin-bottom:10px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:25px;box-shadow:0 4px 12px #0000001a}.chat-input-bottom{flex:1;padding:12px 16px;border:2px solid rgba(255,182,193,.3);border-radius:20px;font-size:.95rem;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;background:#ffffffe6;color:#333;outline:none;transition:all .3s ease}.chat-input-bottom:focus{border-color:#ffb6c199;background:#fff;box-shadow:0 0 0 3px #ffb6c11a}.chat-input-bottom:disabled{opacity:.6;cursor:not-allowed}.chat-send-btn-bottom{padding:12px 24px;border:none;border-radius:20px;background:linear-gradient(135deg,#ffb6c1,#98fb98);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Microsoft YaHei,微软雅黑,Arial,sans-serif;box-shadow:0 2px 8px #ffb6c14d;white-space:nowrap}.chat-send-btn-bottom:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ffb6c166}.chat-send-btn-bottom:active:not(:disabled){transform:translateY(0)}.chat-send-btn-bottom:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.ai-chat-top-right{top:10px;right:10px;gap:8px}.ai-avatar-circle{width:60px;height:60px}.christmas-wreath{width:76px;height:76px;top:-6px;left:-6px}.wreath-ring{border-width:5px}.ai-speech-bubble{max-width:calc(100vw - 100px)}.speech-bubble-content{padding:10px 14px}.speech-bubble-text{font-size:.85rem}.chat-input-area-bottom{padding:12px 15px;margin-top:8px}.chat-input-bottom{padding:10px 14px;font-size:.9rem}.chat-send-btn-bottom{padding:10px 20px;font-size:.9rem}}.gomoku-page{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(180deg,#012,#036,#048);min-height:100vh;overflow-x:hidden;color:#fff}#root{min-height:100vh}@keyframes wave{0%,to{transform:translate(0) translateY(0)}50%{transform:translate(-25%) translateY(-10px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes bubble{0%{transform:translateY(0) scale(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) scale(1);opacity:0}}
