code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-cyan: #00BFFF;--secondary-cyan: #87CEEB;--accent-cyan: #5DADE2;--light-blue: #E3F2FD;--white: #FFFFFF;--light-gray: #F8F9FA;--dark-gray: #2C3E50;--success: #28A745;--warning: #FFC107;--danger: #DC3545;--shadow: rgba(0, 191, 255, .15);--font-family: "Arial", "Helvetica", sans-serif;--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 15px;--border-radius-xl: 20px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 20px;--spacing-xl: 30px;--spacing-2xl: 40px}body{font-family:var(--font-family);background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 50%,var(--secondary-cyan) 100%);min-height:100vh;line-height:1.6;color:var(--dark-gray)}.text-center{text-align:center}.flex-center{display:flex;justify-content:center;align-items:center}.grid-center{display:grid;place-items:center}.gradient-primary{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%)}.gradient-light{background:linear-gradient(135deg,var(--white) 0%,var(--light-blue) 100%)}.gradient-secondary{background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 100%)}.btn{border:none;border-radius:var(--border-radius-md);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;font-weight:600;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-primary{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:2px solid transparent}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--shadow)}.btn-secondary{background:var(--white);color:var(--primary-cyan);border:2px solid var(--primary-cyan)}.btn-secondary:hover{background:var(--light-blue);transform:translateY(-2px)}.card{background:var(--white);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:0 10px 30px var(--shadow);border:2px solid var(--secondary-cyan)}.transition-smooth{transition:all .3s ease}.transition-fast{transition:all .15s ease}.App{text-align:center;min-height:100vh;padding:var(--spacing-lg);color:var(--dark-gray)}.App.playing{padding:0}.App-header{margin-bottom:var(--spacing-2xl);position:relative}.App-header h1{font-size:3rem;margin-bottom:var(--spacing-md);color:var(--primary-cyan);text-shadow:2px 2px 4px var(--shadow);font-weight:700;margin-top:60px}.App-header p{font-size:1.2rem;color:var(--dark-gray);opacity:.8;font-weight:300}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(2px)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);border-bottom:2px solid var(--secondary-cyan)}.modal-header h2{color:var(--primary-cyan);font-size:1.8rem;font-weight:600}.close-btn{background:var(--danger);color:var(--white);border:none;width:35px;height:35px;border-radius:50%;cursor:pointer;font-size:1.2rem;font-weight:700;transition:all .2s ease;display:flex;justify-content:center;align-items:center}.close-btn:hover{background:#c82333;transform:scale(1.1)}.modal-content{padding:var(--spacing-xl);overflow-y:auto;max-height:calc(90vh - 100px)}.btn-primary{background:var(--primary-cyan);color:var(--white);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease}.btn-primary:hover{background:var(--accent-cyan);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.btn-secondary{background:var(--secondary-cyan);color:var(--dark-gray);border:2px solid var(--secondary-cyan);padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease}.btn-secondary:hover{background:var(--white);border-color:var(--primary-cyan);color:var(--primary-cyan)}.btn-danger{background:var(--danger);color:var(--white);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease}.btn-danger:hover{background:#c82333;transform:translateY(-2px)}.form-group{margin-bottom:var(--spacing-lg);text-align:left}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;color:var(--dark-gray)}.form-input{width:100%;padding:var(--spacing-md);border:2px solid var(--secondary-cyan);border-radius:var(--border-radius-sm);font-size:1rem;color:var(--dark-gray);background:var(--white);transition:border-color .3s ease}.form-input:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 3px #00bfff1a}.form-select{width:100%;padding:var(--spacing-md);border:2px solid var(--secondary-cyan);border-radius:var(--border-radius-sm);font-size:1rem;color:var(--dark-gray);background:var(--white);cursor:pointer}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.history-modal{background:var(--white);padding:0;border-radius:var(--border-radius-xl);max-width:1100px;width:95%;max-height:90vh;overflow:hidden;box-shadow:0 10px 30px var(--shadow);border:2px solid var(--secondary-cyan)}.history-modal>.modal-content{background:transparent;border:none;box-shadow:none;width:100%;max-width:100%;padding:var(--spacing-lg);overflow:auto}.stats-section{background:var(--light-blue);padding:var(--spacing-2xl);margin-bottom:var(--spacing-xl);border-radius:var(--border-radius-lg);border:1px solid var(--secondary-cyan)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg)}.stat-item{text-align:center;padding:var(--spacing-lg);background:var(--white);border-radius:var(--border-radius-md);border:1px solid var(--secondary-cyan)}.stat-number{display:block;font-size:2rem;font-weight:700;color:var(--primary-cyan);margin-bottom:var(--spacing-xs)}.filter-section{display:flex;gap:var(--spacing-lg);align-items:center;margin-bottom:25px;padding:15px;background:var(--light-gray);border-radius:var(--border-radius-md);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm)}.filter-group select{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--secondary-cyan);border-radius:var(--border-radius-sm);background:var(--white);color:var(--dark-gray);font-size:.9rem}.clear-history-btn{background:var(--danger);color:var(--white);border:none;padding:var(--spacing-sm) 16px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;margin-left:auto}.no-history{text-align:center;padding:var(--spacing-2xl);color:var(--dark-gray);font-size:1.1rem}.history-list{text-align:initial}.history-list .history-table{border:2px solid var(--secondary-cyan);border-radius:var(--border-radius-md);overflow:hidden;margin:0 auto;width:100%;text-align:center}.history-list .history-table .table-header{display:grid;grid-template-columns:140px 120px 80px 80px 80px 80px 80px 60px;background:var(--primary-cyan);color:var(--white);font-weight:700;padding:15px 10px;font-size:.9rem;text-align:center;justify-items:center;align-items:center}.history-list .history-table .table-header>div{text-align:center;justify-self:center;align-self:center;width:100%;display:flex;justify-content:center;align-items:center}.history-list .history-table .table-row{display:grid;grid-template-columns:140px 120px 80px 80px 80px 80px 80px 60px;padding:12px 10px;border-bottom:1px solid var(--secondary-cyan);font-size:.85rem;text-align:center;justify-items:center;align-items:center}.history-list .history-table .table-row>div{text-align:center;justify-self:center;align-self:center;width:100%;display:flex;justify-content:center;align-items:center}.history-list .history-table .table-row:nth-child(2n){background:var(--light-gray)}.history-list .history-table .table-row:hover{background:var(--light-blue)}.history-list .history-table .date-cell{font-size:.8rem;color:var(--dark-gray);text-align:center;justify-self:center;align-self:center}.history-list .history-table .mode-cell{font-weight:600;color:var(--primary-cyan);text-align:center;justify-self:center;align-self:center}.history-list .history-table .score-cell,.history-list .history-table .accuracy-cell,.history-list .history-table .wpm-cell{text-align:center;font-weight:600;justify-self:center;align-self:center}.history-list .history-table .rating-cell{text-align:center;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;justify-self:center;align-self:center;gap:2px}.history-list .history-table .result-cell{text-align:center;padding:4px 8px;border-radius:var(--border-radius-sm);font-size:.8rem;font-weight:600;justify-self:center;align-self:center}.history-list .history-table .result-cell.completed{background:var(--success);color:var(--white)}.history-list .history-table .result-cell.timeout{background:var(--warning);color:var(--white)}.history-list .history-table .result-cell.quit{background:var(--danger);color:var(--white)}.history-list .history-table .action-cell{text-align:center;display:flex;justify-content:center;align-items:center;justify-self:center;align-self:center}.history-list .history-table .no-rating{text-align:center;color:var(--dark-gray);opacity:.6;justify-self:center;align-self:center}.delete-record-btn{background:var(--danger);color:var(--white);border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:.8rem;font-weight:700;transition:all .2s ease}.history-btn{background:var(--accent-cyan);color:var(--white);border:none;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:var(--spacing-sm)}@media(max-width:768px){.history-list .history-table .table-header,.history-list .history-table .table-row{grid-template-columns:100px 80px 60px 60px 60px 60px 60px 40px;font-size:.75rem;text-align:center;justify-items:center;align-items:center}.history-list .history-table .table-header>div,.history-list .history-table .table-row>div{text-align:center;justify-self:center;align-self:center;justify-content:center;align-items:center}.history-list .history-table .date-cell{font-size:.7rem}.stats-grid{grid-template-columns:1fr}.filter-section{flex-direction:column;align-items:stretch}.custom-words-table-header,.custom-words-table-row{grid-template-columns:1.5fr 1.5fr 60px;padding:var(--spacing-sm)}}@media(max-width:480px){.cta-section{padding:24px 16px;margin-bottom:24px;border-radius:12px}.cta-title{font-size:1.4rem;margin-bottom:6px}.cta-description{font-size:.9rem;line-height:1.5}.history-list .history-table .table-header,.history-list .history-table .table-row{grid-template-columns:80px 70px 50px 50px 50px 50px 50px 35px;font-size:.7rem;padding:8px 5px;text-align:center;justify-items:center;align-items:center}.history-list .history-table .table-header>div,.history-list .history-table .table-row>div{text-align:center;justify-self:center;align-self:center;justify-content:center;align-items:center}.history-list .history-table .date-cell{font-size:.65rem}.delete-record-btn{width:20px;height:20px;font-size:.7rem}}@media(min-width:1200px){.history-list .history-table .table-header,.history-list .history-table .table-row{grid-template-columns:160px 140px 90px 90px 90px 90px 90px 70px;font-size:.95rem}.history-modal{max-width:1200px}}@media print{.modal-overlay{position:static;background:none}.history-modal{box-shadow:none;border:1px solid #000;max-width:100%;max-height:none}.close-btn,.delete-record-btn,.clear-history-btn,.action-cell{display:none}.history-list .history-table .table-header,.history-list .history-table .table-row{grid-template-columns:140px 120px 80px 80px 80px 80px 80px}}.pause-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#2c3e5059;z-index:9999;display:flex;align-items:center;justify-content:center}.pause-modal{background:var(--white);border-radius:16px;box-shadow:0 4px 24px #2c3e502e;padding:32px 32px 24px;min-width:280px;max-width:90vw;text-align:center}.pause-modal h2{font-size:1.5rem;color:var(--primary-cyan);margin-bottom:18px}.pause-modal button{font-size:1.1rem;padding:10px 28px;border-radius:8px;border:none;margin:0 8px;background:var(--accent-cyan);color:var(--white);font-weight:600;cursor:pointer;transition:background .2s}.pause-modal .resume-btn{background:var(--primary-cyan)}.pause-modal .resume-btn:hover{background:#09c}.pause-modal .quit-btn{background:var(--danger)}.pause-modal .quit-btn:hover{background:#b71c1c}.pause-modal .pause-hint{margin-top:18px;font-size:.95rem;color:var(--dark-gray);opacity:.7}:root{--primary-cyan: #00BFFF;--secondary-cyan: #87CEEB;--accent-cyan: #5DADE2;--light-blue: #E3F2FD;--white: #FFFFFF;--light-gray: #F8F9FA;--dark-gray: #2C3E50;--success: #28A745;--warning: #FFC107;--danger: #DC3545;--shadow: rgba(0, 191, 255, .15)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#f0f9ff,#fff,#e0f7fa);min-height:100vh;line-height:1.6}.App{overflow:hidden;height:100vh;color:var(--dark-gray)}.app-slider{display:flex;width:200vw;height:100vh;transition:transform .4s ease-out}.app-page{width:100vw;height:100vh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;flex-shrink:0}.main-page{text-align:center;padding:20px 20px 60px}.main-page.playing{padding:0}.stats-page{background:linear-gradient(180deg,#f0f9ff,#fff,#e0f7fa)}.App-header{margin-bottom:20px;position:relative}.hero-content{text-align:center;padding:50px 20px 40px;animation:fadeInUp .6s ease-out}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:50px;margin-bottom:12px;font-size:.85rem;background:#00bfff14;border:1px solid rgba(0,191,255,.2);color:var(--primary-cyan)}.hero-badge-icon{font-size:.9rem}.hero-title{font-size:1.8rem;margin-bottom:12px;font-weight:700;line-height:1.2;color:var(--dark-gray)}.hero-subtitle-main{font-size:1rem;font-weight:400;line-height:1.6;color:var(--dark-gray);margin:0}.gradient-text{background:linear-gradient(135deg,#00bfff,#5dade2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:500}@media(min-width:640px){.hero-content{padding:60px 20px 45px}.hero-badge{font-size:.9rem;padding:8px 18px}.hero-title{font-size:2.2rem}.hero-subtitle-main{font-size:1.1rem}}@media(max-width:480px){.hero-content{padding:40px 15px 30px}.hero-badge{font-size:.75rem;padding:6px 12px;margin-bottom:10px}.hero-title{font-size:1.5rem;margin-bottom:10px}.hero-subtitle-main{font-size:.9rem}}.menu-container{max-width:700px;margin:0 auto;background:#ffffffe6;backdrop-filter:blur(10px);padding:40px;border-radius:20px;box-shadow:0 10px 40px var(--shadow);border:1px solid rgba(135,206,235,.3);transition:all .3s ease;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-container:hover{box-shadow:0 15px 50px #00bfff40;transform:translateY(-2px)}.menu-container h2{font-size:2rem;margin-bottom:30px;color:var(--primary-cyan);font-weight:600}.mode-section{margin-bottom:40px;padding:30px;background:linear-gradient(135deg,#e3f2fdcc,#ffffffe6);border-radius:16px;border:1px solid rgba(135,206,235,.4);transition:all .3s ease}.mode-section:hover{border-color:var(--primary-cyan);box-shadow:0 5px 20px #00bfff26}.mode-section h3{font-size:1.5rem;margin-bottom:10px;color:var(--accent-cyan);font-weight:600}.mode-description{color:var(--dark-gray);margin-bottom:20px;opacity:.8}.level-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-top:20px}.level-btn{background:#ffffffe6;border:2px solid rgba(0,191,255,.3);border-radius:12px;padding:15px 12px;cursor:pointer;transition:all .3s ease;color:var(--dark-gray);font-weight:600;min-height:80px;display:flex;flex-direction:column;justify-content:center;align-items:center;backdrop-filter:blur(5px)}.level-btn:hover{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);transform:translateY(-5px);box-shadow:0 10px 30px #00bfff4d;border-color:transparent}.level-btn:active{transform:translateY(-2px)}.level-desc{font-size:.9rem;opacity:.8;margin-top:5px;font-weight:400}.level-1,.conversation-1,.chat-1{border-color:var(--secondary-cyan)}.level-2,.conversation-2,.chat-2{border-color:var(--primary-cyan)}.level-3,.conversation-3,.chat-3{border-color:var(--accent-cyan)}.level-4,.conversation-4,.chat-4{border-color:#4682b4}.chat-1,.chat-2,.chat-3,.chat-4{background:linear-gradient(135deg,var(--white) 0%,rgba(0,191,255,.05) 100%);position:relative;overflow:hidden}.chat-1:before,.chat-2:before,.chat-3:before,.chat-4:before{content:"💬";position:absolute;top:8px;right:8px;font-size:1.2rem;opacity:.7}.chat-1:hover,.chat-2:hover,.chat-3:hover,.chat-4:hover{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);border-color:var(--primary-cyan);box-shadow:0 8px 25px #00bfff4d}.options{margin-top:30px;padding:20px;background:var(--white);border-radius:10px;border:1px solid var(--secondary-cyan)}.translation-toggle{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1rem;color:var(--dark-gray);cursor:pointer}.translation-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary-cyan)}.time-setting{margin-top:15px;text-align:center}.time-label{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1rem;color:var(--dark-gray);font-weight:600}.time-select{padding:8px 12px;border:2px solid var(--secondary-cyan);border-radius:8px;background:var(--white);color:var(--dark-gray);font-size:1rem;cursor:pointer;transition:all .3s ease;min-width:140px}.time-select:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 3px #00bfff1a}.time-select:hover{border-color:var(--primary-cyan)}.game-container{max-width:700px;margin:40px auto 80px;background:#fffffff2;backdrop-filter:blur(10px);padding:30px;border-radius:20px;box-shadow:0 10px 40px var(--shadow);border:1px solid rgba(135,206,235,.3);animation:fadeInUp .4s ease-out}.game-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;margin-bottom:40px}.info-item{background:var(--light-blue);padding:12px 10px;border-radius:10px;border:1px solid var(--secondary-cyan)}.info-label{display:block;font-size:.9rem;color:var(--dark-gray);opacity:.8;margin-bottom:5px}.info-value{font-size:1.4rem;font-weight:700;color:var(--primary-cyan)}.timer{color:var(--warning)}.word-display{margin:40px 0;padding:40px;background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 100%);border-radius:15px;border:2px solid var(--secondary-cyan)}.current-word{font-size:3rem;font-weight:700;color:var(--primary-cyan);margin-bottom:15px;text-shadow:1px 1px 2px var(--shadow)}.translation{font-size:1.3rem;color:var(--dark-gray);opacity:.8}.input-section{display:flex;flex-direction:column;gap:15px;justify-content:center;align-items:center;margin:30px 0}.word-input{width:100%;max-width:400px;padding:15px 20px;font-size:1.2rem;border:2px solid var(--secondary-cyan);border-radius:10px;background:var(--white);color:var(--dark-gray);transition:all .3s ease}.submit-btn{padding:15px 30px;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease}.submit-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-2px);box-shadow:0 5px 15px var(--shadow)}.progress-bar{width:100%;height:8px;background:var(--light-blue);border-radius:4px;overflow:hidden;border:1px solid var(--secondary-cyan)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);transition:width .3s ease}.result-container{max-width:550px;margin:0 auto 100px;background:#fffffff2;backdrop-filter:blur(10px);padding:30px;border-radius:20px;box-shadow:0 10px 40px var(--shadow);border:1px solid rgba(135,206,235,.3)}.result-container h2{font-size:2rem;margin-bottom:15px;color:var(--primary-cyan);font-weight:700}.completed-level{font-size:1rem;color:var(--dark-gray);margin-bottom:20px;opacity:.8}.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;margin:16px 0}.stat-item{background:var(--light-blue);padding:7px 8px;border-radius:12px;border:1px solid var(--secondary-cyan);text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;color:var(--primary-cyan);margin-bottom:5px}.stat-label{font-size:.9rem;color:var(--dark-gray);opacity:.8}.restart-btn{margin-top:20px;margin-bottom:20px;padding:12px 32px;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease}.restart-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-2px);box-shadow:0 8px 20px var(--shadow)}.chat-history-section{margin-top:20px;margin-bottom:30px;width:100%}.chat-history-display{background:var(--white);border:2px solid var(--light-blue);border-radius:12px;padding:12px;max-height:200px;overflow-y:auto}.chat-history-display h3{color:var(--primary-cyan);margin-bottom:12px;font-size:1.1rem;text-align:center}.chat-history-messages{display:flex;flex-direction:column;gap:8px}.history-message{display:flex;width:100%}.history-message.japanese{justify-content:flex-start}.history-message.english{justify-content:flex-end}.history-message-bubble{max-width:70%;padding:12px 16px;border-radius:16px;font-size:.9rem}.history-message.japanese .history-message-bubble{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border-bottom-left-radius:4px}.history-message.english .history-message-bubble{background:var(--light-blue);color:var(--dark-gray);border:1px solid var(--secondary-cyan);border-bottom-right-radius:4px}.history-message-text{font-weight:500;line-height:1.4;margin-bottom:4px}.history-correction{font-size:.8rem;color:#666;font-weight:400;margin-top:6px;padding-top:6px;border-top:1px solid rgba(102,102,102,.3);opacity:.8}.history-message-time{font-size:.7rem;opacity:.7;text-align:right;margin-top:4px}.chat-history-display::-webkit-scrollbar{width:6px}.chat-history-display::-webkit-scrollbar-track{background:var(--light-blue);border-radius:3px}.chat-history-display::-webkit-scrollbar-thumb{background:var(--secondary-cyan);border-radius:3px}.chat-history-display::-webkit-scrollbar-thumb:hover{background:var(--accent-cyan)}.history-message.game-item{margin-bottom:15px}.history-message.game-item .history-message-bubble{position:relative;padding:15px;background:var(--light-blue);border-left:4px solid var(--secondary-cyan)}.history-message.game-item.correct .history-message-bubble{border-left-color:#10b981;background:#10b9811a}.history-message.game-item.incorrect .history-message-bubble{border-left-color:#ef4444;background:#ef44441a}.bookmark-toggle{position:absolute;top:10px;right:10px;background:transparent;border:none;cursor:pointer;padding:8px;z-index:1;outline:none}.bookmark-toggle:focus{outline:none}.bookmark-icon{width:24px;height:24px;transition:all .2s ease}.bookmark-toggle .bookmark-icon path{fill:transparent;stroke:var(--primary-cyan);stroke-width:2}.bookmark-toggle.active .bookmark-icon path{fill:var(--primary-cyan);stroke:var(--primary-cyan);stroke-width:2}.bookmark-toggle:hover .bookmark-icon{transform:scale(1.1)}.game-problem{margin-bottom:10px}.english-text{font-size:1.1em;font-weight:700;color:var(--text-primary);margin-bottom:5px}.japanese-text{color:var(--text-secondary);font-size:.9em}.user-answer{display:flex;align-items:center;gap:8px;margin-bottom:8px}.answer-label{font-size:.9em;color:var(--text-secondary)}.answer-text{font-weight:700;padding:4px 8px;border-radius:4px}.correct-answer{background:#10b98133;color:#10b981}.incorrect-answer{background:#ef444433;color:#ef4444}.result-icon{font-weight:700;font-size:1.1em}.result-icon.correct{color:#10b981}.result-icon.incorrect{color:#ef4444}@media(max-width:768px){.App{padding:15px 15px 80px}.App.playing{padding:0}.App-header h1{font-size:2rem;margin-top:60px;max-width:90%}.menu-container,.game-container,.result-container{padding:25px;margin:20px 10px}.contact-section{margin:20px 10px;padding:15px}.contact-main-btn{padding:12px 25px;font-size:1rem;min-width:160px}.level-buttons{grid-template-columns:1fr}.current-word{font-size:2.2rem}.input-section{flex-direction:column;gap:15px}.word-input{max-width:100%}.result-stats{grid-template-columns:repeat(4,1fr);gap:4px}.result-stats .stat-item{padding:6px 4px}.result-stats .stat-number{font-size:1.5rem;margin-bottom:2px}.result-stats .stat-label{font-size:.7rem;white-space:nowrap}.game-info{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:20px}.game-info .info-item{padding:8px 4px}.game-info .info-label{font-size:.65rem}.game-info .info-value{font-size:1.1rem}.game-info .quit-btn{padding:4px 6px;font-size:.65rem;border-radius:6px}.game-info .keyboard-hint{font-size:.5rem;margin-top:2px}.bookmark-icon{width:20px;height:20px}.chat-typing-game{height:85vh;margin:10px}.game-info-header{grid-template-columns:repeat(4,1fr);gap:6px;padding:8px 12px}.game-info-header .info-item{padding:6px 4px}.game-info-header .info-label{font-size:.7rem}.game-info-header .info-value{font-size:1.2rem}.game-info-header .quit-btn{padding:6px 10px;font-size:.75rem}.game-info-header .keyboard-hint{font-size:.6rem}.message-bubble{max-width:85%;padding:12px 16px;font-size:.95rem}.chat-container{padding:15px}.chat-messages{gap:6px}.chat-input-area{padding:15px}.input-container{flex-direction:column;gap:10px}.send-btn{width:100%;justify-self:stretch}.current-translation{font-size:.8rem}}.sound-toggle-btn{position:fixed;bottom:80px;right:20px;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);border:none;border-radius:50%;width:50px;height:50px;font-size:1.5rem;color:#fff;cursor:pointer;box-shadow:0 4px 12px var(--shadow);transition:all .3s ease;z-index:10000;display:flex;align-items:center;justify-content:center}.sound-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px var(--shadow);opacity:1}.sound-toggle-btn:active{transform:scale(.95)}.settings-gear-btn{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);border:none;border-radius:50%;width:50px;height:50px;font-size:1.5rem;color:#fff;cursor:pointer;box-shadow:0 4px 12px var(--shadow);transition:all .3s ease;z-index:10000;display:flex;align-items:center;justify-content:center}.feedback-button{position:fixed;bottom:20px;left:20px;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);border:2px solid var(--secondary-cyan);border-radius:50%;width:50px;height:50px;color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow);z-index:10000;display:flex;align-items:center;justify-content:center}.feedback-button:hover{transform:translateY(-2px) scale(1.1);box-shadow:0 6px 16px var(--shadow);background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);border-color:var(--primary-cyan)}.settings-gear-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px var(--shadow)}.swipe-dots{position:fixed;bottom:28px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:6px 12px;background:#80808026;border-radius:12px;z-index:600}.swipe-dot{width:8px;height:8px;border-radius:50%;background:var(--dark-gray);opacity:.4;cursor:pointer;transition:opacity .3s}.swipe-dot.active{opacity:1;background:var(--primary-cyan)}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px;backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.modal-content{background:linear-gradient(145deg,var(--white) 0%,var(--light-blue) 100%);border:2px solid var(--secondary-cyan);border-radius:15px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px var(--shadow);animation:slideIn .3s ease-out;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 15px;background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 100%);border-bottom:2px solid var(--secondary-cyan);border-radius:12px 12px 0 0;margin-bottom:20px}.modal-header h2{margin:0;color:var(--primary-cyan);font-size:1.5rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.1)}.close-btn{background:linear-gradient(135deg,var(--light-gray) 0%,var(--white) 100%);border:2px solid var(--secondary-cyan);border-radius:50%;width:40px;height:40px;cursor:pointer;color:var(--dark-gray);padding:0;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-btn:hover{background:linear-gradient(135deg,var(--danger) 0%,#ff4757 100%);color:#fff;transform:rotate(90deg);border-color:var(--danger)}[class$=-modal]>.modal-content{background:transparent;border:none;box-shadow:none;width:100%;max-width:100%;padding:16px;overflow:auto}.form-description{color:#6c757d;margin-bottom:20px;padding:0 20px;line-height:1.5}form{padding:0 20px 20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333}.required{color:#dc3545;font-weight:700}.form-input,.form-textarea,.form-select{width:100%;padding:12px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-textarea{resize:vertical;min-height:100px;font-family:inherit}.form-select{background:#fff;cursor:pointer}.form-input.error,.form-textarea.error,.form-select.error{border-color:#dc3545;background-color:#fff5f5}.error-message{display:block;color:#dc3545;font-size:14px;margin-top:5px;font-weight:500}.form-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:120px}.submit-btn{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:#fff;width:100%;margin-top:10px;border:2px solid var(--secondary-cyan)}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-2px);box-shadow:0 5px 15px var(--shadow)}.submit-btn:disabled{background:var(--light-gray);color:var(--dark-gray);opacity:.6;cursor:not-allowed;transform:none;border-color:var(--light-gray)}.back-btn{background:linear-gradient(135deg,var(--success) 0%,#20c997 100%);color:#fff;width:100%;border:2px solid var(--success)}.back-btn:hover{background:linear-gradient(135deg,#20c997 0%,var(--success) 100%);transform:translateY(-2px);box-shadow:0 5px 15px #28a7454d}.success-modal{text-align:center;padding:40px 20px}.success-animation{margin-bottom:20px}.checkmark{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;background-color:#28a745;color:#fff;border-radius:50%;font-size:30px;font-weight:700;animation:checkmarkBounce .6s ease-out}.success-modal h2{color:#28a745;margin-bottom:20px}.success-message{margin-bottom:30px}.success-message p{margin-bottom:10px;color:#333;line-height:1.6}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes checkmarkBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2);opacity:.8}to{transform:scale(1);opacity:1}}.settings-gear-btn:active{transform:scale(.95)}.settings-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px;backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.settings-modal{background:linear-gradient(145deg,var(--white) 0%,var(--light-blue) 100%);border:2px solid var(--secondary-cyan);border-radius:15px;padding:0;max-width:400px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 30px var(--shadow);animation:slideIn .3s ease-out}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 15px;background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 100%);border-bottom:2px solid var(--secondary-cyan);border-radius:12px 12px 0 0;margin-bottom:0}.settings-header h3{margin:0;color:var(--primary-cyan);font-size:1.5rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.1)}.settings-header .close-btn{background:linear-gradient(135deg,var(--light-gray) 0%,var(--white) 100%);border:2px solid var(--secondary-cyan);border-radius:50%;width:40px;height:40px;cursor:pointer;color:var(--dark-gray);padding:0;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-size:18px}.settings-header .close-btn:hover{background:linear-gradient(135deg,var(--danger) 0%,#ff4757 100%);color:#fff;transform:rotate(90deg);border-color:var(--danger)}.settings-content{padding:20px}.setting-section{margin-bottom:25px;border-bottom:2px solid var(--secondary-cyan);background:linear-gradient(135deg,var(--white) 0%,var(--light-blue) 50%);border-radius:10px;padding:15px}.setting-section:last-child{margin-bottom:0;border-bottom:none}.setting-section .mode-description{color:var(--dark-gray);margin-bottom:12px;opacity:.75;font-size:.85rem;line-height:1.5}.setting-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.setting-title h4{margin:0;color:var(--primary-cyan);font-size:1.1rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.toggle-btn{background:linear-gradient(135deg,var(--light-gray) 0%,var(--white) 100%);border:2px solid var(--secondary-cyan);border-radius:20px;padding:8px 16px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:60px;box-shadow:0 2px 8px var(--shadow)}.toggle-btn.enabled{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:#fff;border-color:var(--primary-cyan);transform:translateY(-1px)}.toggle-btn.disabled{background:linear-gradient(135deg,var(--light-gray) 0%,var(--white) 100%);color:var(--dark-gray);border-color:var(--secondary-cyan)}.toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.volume-setting{margin-top:10px}.volume-label{display:flex;align-items:center;gap:10px;font-size:.95rem;color:var(--text-secondary)}.volume-control-group{display:flex;align-items:center;gap:10px;flex:1}.volume-slider{flex:1;height:6px;background:var(--light-blue);border-radius:3px;outline:none;transition:all .3s ease}.volume-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--secondary-cyan);cursor:pointer;transition:all .3s ease}.volume-slider::-webkit-slider-thumb:hover{background:var(--accent-cyan);transform:scale(1.2)}.volume-value{font-weight:600;color:var(--primary-cyan);min-width:40px;text-align:right}.coming-soon{color:var(--text-secondary);font-style:italic;margin:0}.clear-data-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;border:2px solid #ff4757;border-radius:8px;padding:10px 16px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;margin-top:10px;font-size:.95rem;box-shadow:0 2px 8px #ff47574d}.clear-data-btn:hover{background:linear-gradient(135deg,#ff5252,#e74c3c);transform:translateY(-2px);box-shadow:0 4px 12px #ff475766}.clear-data-btn:active{transform:translateY(0)}.clear-confirm-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10002;padding:20px;backdrop-filter:blur(8px);animation:fadeIn .2s ease-out}.clear-confirm-modal{background:linear-gradient(145deg,var(--white) 0%,var(--light-blue) 100%);border:3px solid #ff6b6b;border-radius:16px;padding:24px;max-width:400px;width:90%;box-shadow:0 15px 40px #ff47574d;animation:slideIn .3s ease-out}.clear-confirm-modal h3{margin:0 0 16px;color:#e74c3c;font-size:1.3rem;font-weight:700;text-align:center}.confirm-message{font-weight:600;color:var(--dark-gray);margin:0 0 16px;font-size:1rem;text-align:center}.confirm-list{list-style:none;margin:0 0 16px;background:#ff6b6b1a;border-radius:8px;padding:12px}.confirm-list li{padding:6px 0 6px 24px;position:relative;font-size:.9rem;color:#c0392b;font-weight:500}.confirm-list li:before{content:"×";position:absolute;left:0;font-weight:700;color:#e74c3c;font-size:1.2em}.confirm-warning{font-size:.85rem;color:#e67e22;margin:0 0 20px;font-weight:600;text-align:center;background:#e67e221a;padding:8px;border-radius:6px}.confirm-actions{display:flex;gap:12px}.cancel-btn{flex:1;background:linear-gradient(135deg,#ecf0f1,#bdc3c7);color:#2c3e50;border:2px solid #95a5a6;border-radius:10px;padding:12px 16px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem;box-shadow:0 2px 8px #95a5a64d}.cancel-btn:hover{background:linear-gradient(135deg,#bdc3c7,#95a5a6);transform:translateY(-2px);box-shadow:0 4px 12px #95a5a666}.confirm-clear-btn{flex:1;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:2px solid #c0392b;border-radius:10px;padding:12px 16px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem;box-shadow:0 2px 8px #e74c3c4d}.confirm-clear-btn:hover{background:linear-gradient(135deg,#c0392b,#a93226);transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c80}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.volume-control{display:flex;flex-direction:column;align-items:center;gap:5px;width:100%}.volume-label{font-size:.8rem;color:var(--dark-gray);opacity:.8;font-weight:500}.volume-slider{width:80px;height:4px;background:var(--light-blue);border-radius:2px;outline:none;cursor:pointer;accent-color:var(--primary-cyan)}.bgm-controls{display:flex;flex-direction:column;gap:8px;align-items:center;padding-top:10px;border-top:1px solid var(--secondary-cyan);width:100%}.bgm-toggle{background:linear-gradient(135deg,var(--secondary-cyan) 0%,var(--accent-cyan) 100%);border:none;border-radius:6px;color:var(--white);font-size:.9rem;padding:6px 12px;cursor:pointer;transition:all .3s ease;font-weight:500}.bgm-toggle:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--secondary-cyan) 100%);transform:translateY(-1px)}.bgm-toggle.disabled{background:var(--light-gray);color:var(--dark-gray)}.volume-display{font-size:.8rem;color:var(--primary-cyan);font-weight:600;min-width:30px;text-align:right}@media(max-width:480px){.App-header h1{margin-top:20px;font-size:1.8rem;max-width:100%}.sound-control{padding:10px;min-width:100px}.current-word{font-size:1.8rem}.translation{font-size:1.1rem}.chat-typing-game{height:90vh;margin:5px}.game-info-header{grid-template-columns:repeat(4,1fr);gap:4px;padding:6px 8px}.game-info-header .info-item{padding:4px 2px;border-radius:6px}.game-info-header .info-label{font-size:.65rem}.game-info-header .info-value{font-size:1.1rem}.game-info-header .quit-btn{padding:4px 8px;font-size:.7rem;border-radius:6px}.game-info-header .keyboard-hint{font-size:.55rem;margin-top:2px}.message-bubble{max-width:90%;padding:10px 14px;font-size:.9rem}.message-text{font-size:1rem}.chat-messages{gap:5px}.chat-input{font-size:16px}}button:focus,input:focus{outline:2px solid var(--primary-cyan);outline-offset:2px}button:disabled{opacity:.6;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-container,.game-container,.result-container{animation:fadeIn .5s ease-out}button{font-family:inherit;transition:all .3s ease}input{font-family:inherit}.custom-word-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:20px}.custom-manage-btn,.custom-play-btn{background:linear-gradient(135deg,var(--secondary-cyan) 0%,var(--accent-cyan) 100%);border:2px solid var(--accent-cyan);color:var(--white)}.custom-manage-btn:hover,.custom-play-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);border-color:var(--primary-cyan);color:var(--white)}.custom-play-btn:disabled{background:var(--light-gray);color:var(--dark-gray);border-color:var(--light-gray);opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .3s ease}.custom-words-modal{background:var(--white);border-radius:20px;border:2px solid var(--secondary-cyan);width:90%;max-width:900px;max-height:90vh;overflow:hidden;animation:slideUp .3s ease;box-shadow:0 15px 35px var(--shadow)}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid var(--light-blue);background:var(--light-blue)}.modal-header h2{color:var(--primary-cyan);font-size:1.8rem;font-weight:600;margin:0}.close-btn{background:var(--white);border:2px solid var(--secondary-cyan);color:var(--primary-cyan);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.4rem;font-weight:700;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:var(--danger);color:var(--white);border-color:var(--danger);transform:scale(1.1)}.modal-content{padding:30px;max-height:70vh;overflow-y:auto;color:var(--dark-gray)}.message{padding:12px 20px;border-radius:8px;margin-bottom:20px;font-weight:500;animation:fadeIn .3s ease}.message.success{background:#28a7451a;color:var(--success);border:1px solid var(--success)}.message.error{background:#dc35451a;color:var(--danger);border:1px solid var(--danger)}.add-word-section{background:var(--light-blue);padding:25px;border-radius:15px;margin-bottom:30px;border:1px solid var(--secondary-cyan)}.add-word-section h3{color:var(--primary-cyan);margin-bottom:20px;font-size:1.3rem;font-weight:600}.add-word-form{width:100%}.input-group{display:grid;grid-template-columns:1fr 1fr auto;gap:15px;align-items:center}.word-input{padding:12px 16px;border:2px solid var(--secondary-cyan);border-radius:8px;background:var(--white);color:var(--dark-gray);font-size:1rem;transition:all .3s ease}.word-input:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 3px #00bfff1a}.add-btn{padding:12px 24px;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.add-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow)}.words-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;gap:20px;flex-wrap:wrap}.search-section{flex:1;min-width:200px}.search-input{width:100%;padding:12px 16px;border:2px solid var(--secondary-cyan);border-radius:8px;background:var(--white);color:var(--dark-gray);font-size:1rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 3px #00bfff1a}.action-buttons{display:flex;gap:15px;flex-wrap:wrap}.start-game-btn,.export-btn{padding:10px 18px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-size:.95rem}.start-game-btn{background:linear-gradient(135deg,var(--success) 0%,#20A745 100%);color:var(--white)}.start-game-btn:hover:not(:disabled){background:linear-gradient(135deg,#20A745 0%,var(--success) 100%);transform:translateY(-1px);box-shadow:0 4px 12px #28a7454d}.start-game-btn:disabled{background:var(--light-gray);color:var(--dark-gray);opacity:.6;cursor:not-allowed}.export-btn{background:linear-gradient(135deg,var(--secondary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white)}.export-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--secondary-cyan) 100%);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow)}.export-btn:disabled{background:var(--light-gray);color:var(--dark-gray);opacity:.6;cursor:not-allowed}.words-list h3{color:var(--primary-cyan);margin-bottom:20px;font-size:1.3rem;font-weight:600}.no-words{text-align:center;color:var(--dark-gray);opacity:.7;padding:40px 20px;background:var(--light-blue);border-radius:10px;border:1px solid var(--secondary-cyan)}.words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px}.word-item{background:var(--white);border:2px solid var(--secondary-cyan);border-radius:12px;padding:20px;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center}.word-item:hover{border-color:var(--primary-cyan);box-shadow:0 4px 15px var(--shadow);transform:translateY(-2px)}.word-content{flex:1}.word-english{font-size:1.2rem;font-weight:600;color:var(--primary-cyan);margin-bottom:5px}.word-japanese{font-size:1rem;color:var(--dark-gray);opacity:.8}.word-actions{display:flex;gap:8px;margin-left:15px}.edit-btn,.delete-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:700;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.edit-btn{background:var(--warning);color:var(--white)}.edit-btn:hover{background:#e0a800;transform:scale(1.1)}.delete-btn{background:var(--danger);color:var(--white)}.delete-btn:hover{background:#c82333;transform:scale(1.1)}.edit-form{width:100%;display:flex;flex-direction:column;gap:10px}.edit-input{padding:8px 12px;border:2px solid var(--secondary-cyan);border-radius:6px;background:var(--white);color:var(--dark-gray);font-size:.9rem;transition:all .3s ease}.edit-input:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 2px #00bfff1a}.edit-buttons{display:flex;gap:8px;justify-content:flex-end}.save-btn,.cancel-btn{padding:6px 12px;border:none;border-radius:4px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.save-btn{background:var(--success);color:var(--white)}.save-btn:hover{background:#20a745}.cancel-btn{background:var(--light-gray);color:var(--dark-gray)}.cancel-btn:hover{background:#e9ecef}.quit-btn{padding:10px 20px;background:var(--white);color:var(--danger);border:2px solid var(--danger);border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem;position:relative;overflow:hidden;backdrop-filter:blur(10px);box-shadow:0 2px 8px #dc35451a}.quit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(220,53,69,.1),transparent);transition:left .5s ease}.quit-btn:hover:before{left:100%}.quit-btn:hover{background:var(--danger);color:var(--white);transform:translateY(-2px);box-shadow:0 6px 20px #dc35454d;border-color:var(--danger)}.quit-btn:active{transform:translateY(0);box-shadow:0 2px 8px #dc354533}.keyboard-hint{font-size:.75rem;color:var(--secondary-text);opacity:.7;margin-top:4px;text-align:center;font-style:italic}@media(max-width:768px){.keyboard-hint,.pause-hint{display:none}}.preset-words-modal{background:var(--white);border-radius:20px;border:2px solid var(--secondary-cyan);width:95%;max-width:1200px;max-height:90vh;overflow:hidden;animation:slideUp .3s ease;box-shadow:0 15px 35px var(--shadow)}.stats-overview{background:var(--light-blue);padding:20px;border-radius:10px;margin-bottom:20px;border:1px solid var(--secondary-cyan)}.stats-overview h3{color:var(--primary-cyan);margin-bottom:15px;font-size:1.3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px}.stat-box{background:var(--white);padding:15px;border-radius:8px;border:1px solid var(--secondary-cyan)}.stat-box strong{color:var(--primary-cyan);display:block;margin-bottom:8px}.filters-section{display:flex;gap:20px;align-items:end;margin-bottom:20px;flex-wrap:wrap;padding:20px;background:var(--light-blue);border-radius:10px;border:1px solid var(--secondary-cyan)}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-weight:600;color:var(--dark-gray);font-size:.9rem}.filter-select{padding:8px 12px;border:2px solid var(--secondary-cyan);border-radius:6px;background:var(--white);color:var(--dark-gray);font-size:.9rem;min-width:120px}.filter-select:focus{outline:none;border-color:var(--primary-cyan);box-shadow:0 0 0 2px #00bfff1a}.data-table{border:2px solid var(--secondary-cyan);border-radius:10px;overflow:hidden;background:var(--white);max-height:400px;overflow-y:auto}.custom-words-table-header{display:grid;grid-template-columns:2fr 2fr 80px;background:var(--primary-cyan);color:var(--white);font-weight:600;padding:12px;position:sticky;top:0;z-index:10;text-align:center;place-items:center}.table-body{max-height:360px;overflow-y:auto}.custom-words-table-row{display:grid;grid-template-columns:2fr 2fr 80px;padding:10px 12px;border-bottom:1px solid var(--light-blue);transition:background-color .2s ease;text-align:center;place-items:center}.custom-words-table-row:hover{background:var(--light-blue)}.custom-words-table-row:last-child{border-bottom:none}.col-english{font-weight:600;color:var(--primary-cyan)}.col-japanese{color:var(--dark-gray)}.col-level{text-align:center;font-weight:600;color:var(--accent-cyan)}.no-data{text-align:center;color:var(--dark-gray);opacity:.7;padding:40px 20px;background:var(--light-blue);border-radius:10px;border:1px solid var(--secondary-cyan)}.chat-typing-game{max-width:700px;margin:40px auto;height:65vh;display:flex;flex-direction:column;background:var(--white);border-radius:20px;box-shadow:0 10px 30px var(--shadow);border:2px solid var(--secondary-cyan);overflow:hidden}.game-info-header{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:4px 12px;padding:6px 20px 4px;background:var(--light-blue);border-bottom:2px solid var(--secondary-cyan);min-height:auto}.game-info-header .info-item{background:var(--white);padding:4px 8px;border-radius:8px;border:1px solid var(--secondary-cyan);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1px}.game-info-header .info-label{font-size:.75rem;color:var(--dark-gray);opacity:.8}.game-info-header .info-value{font-size:1.5rem;font-weight:700;color:var(--primary-cyan)}.chat-container{flex:1;overflow-y:auto;padding:20px;background:linear-gradient(180deg,var(--white) 0%,var(--light-blue) 100%);scroll-behavior:smooth}.chat-messages{display:flex;flex-direction:column;gap:8px;min-height:100%}.message{display:flex;animation:messageSlideIn .3s ease-out}.message.japanese{justify-content:flex-start}.message.english{margin-bottom:0;justify-content:flex-end}.message-bubble{max-width:65%;padding:6px 16px;border-radius:20px;position:relative;box-shadow:0 2px 8px #0000001a}.message.japanese .message-bubble{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border-bottom-left-radius:5px;margin-right:auto}.message.english .message-bubble{background:var(--white);color:var(--dark-gray);border:2px solid var(--secondary-cyan);border-bottom-right-radius:5px;margin-left:auto}.message.english .message-bubble.typing{background:var(--light-blue);border-color:var(--accent-cyan)}.message-text{font-size:.95rem;line-height:1.4;margin-bottom:1px;font-weight:500}.correction{font-size:.9rem;color:#666;font-weight:500;margin-top:8px;padding-top:8px;border-top:1px solid rgba(102,102,102,.3);opacity:.8}.message-time{font-size:.7rem;opacity:.7;text-align:right;margin-top:0}.typing-indicator{display:flex;gap:4px;align-items:center;justify-content:center;padding:5px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--accent-cyan);animation:typingBounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-input-area{padding:24px 20px;background:var(--white);border-top:2px solid var(--secondary-cyan)}.input-container{display:flex;gap:12px;align-items:center;margin-bottom:10px}.chat-input{flex:1;padding:12px 18px;font-size:1rem;border:2px solid var(--secondary-cyan);border-radius:25px;background:var(--light-blue);color:var(--dark-gray);transition:all .3s ease;outline:none}.chat-input:focus{border-color:var(--primary-cyan);box-shadow:0 0 0 3px #00bfff1a;background:var(--white)}.chat-input:disabled{opacity:.6;cursor:not-allowed}.send-btn{padding:12px 20px;background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;border-radius:25px;cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.send-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow)}.send-btn:disabled{background:var(--light-gray);color:var(--dark-gray);opacity:.6;cursor:not-allowed;transform:none}.current-translation{text-align:center;font-size:.9rem;color:var(--accent-cyan);font-weight:500;opacity:.8;padding:8px;background:#5dade21a;border-radius:15px;border:1px solid rgba(93,173,226,.3)}.message.english .message-bubble.correct{border-color:var(--success);background:#28a7451a}.message.english .message-bubble.incorrect{border-color:var(--danger);background:#dc35451a}.chat-container::-webkit-scrollbar{width:8px}.chat-container::-webkit-scrollbar-track{background:var(--light-blue);border-radius:4px}.chat-container::-webkit-scrollbar-thumb{background:var(--secondary-cyan);border-radius:4px}.chat-container::-webkit-scrollbar-thumb:hover{background:var(--accent-cyan)}@media(max-width:768px){.custom-words-modal,.preset-words-modal{width:95%;margin:20px}.modal-content{padding:20px}.input-group{grid-template-columns:1fr;gap:10px}.words-controls{flex-direction:column;align-items:stretch}.action-buttons{justify-content:center}.words-grid{grid-template-columns:1fr}.word-item{flex-direction:column;align-items:stretch;gap:15px}.word-actions{justify-content:center;margin-left:0}.custom-word-controls{grid-template-columns:1fr}.filters-section{flex-direction:column;align-items:stretch;gap:15px}.filter-group{width:100%}.filter-select{min-width:auto;width:100%}.data-table{font-size:.8rem}.custom-words-table-header,.custom-words-table-row{grid-template-columns:1.5fr 1.5fr 60px;padding:8px}.stats-grid{grid-template-columns:1fr}}.csv-info-section{background:var(--light-blue);border:2px solid var(--secondary-cyan);border-radius:10px;padding:20px;margin-bottom:25px}.csv-info-section h3{color:var(--primary-cyan);margin-bottom:15px;font-size:1.2rem}.csv-format-info{margin-bottom:15px;color:var(--dark-gray);font-size:.95rem}.csv-example{background:var(--white);border:1px solid var(--secondary-cyan);border-radius:8px;padding:15px;text-align:left}.csv-example code{display:block;font-family:Courier New,monospace;font-size:.9rem;line-height:1.4;color:var(--dark-gray);background:transparent}.csv-buttons{display:flex;gap:10px;align-items:center}.import-btn{background:var(--accent-cyan);color:var(--white);border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;display:inline-block;text-decoration:none}.import-btn:hover{background:var(--primary-cyan);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.import-btn:active{transform:translateY(0)}.message.warning{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.history-modal{background:var(--white);border-radius:20px;width:90%;max-width:1000px;max-height:90vh;overflow:hidden;box-shadow:0 20px 40px var(--shadow);animation:slideUp .3s ease}.stats-section{background:var(--light-blue);border-radius:15px;padding:20px;margin-bottom:25px}.stats-section h3{color:var(--primary-cyan);margin-bottom:15px;font-size:1.3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px}.stat-item{background:var(--white);border-radius:10px;padding:15px;text-align:center;border:2px solid var(--secondary-cyan)}.stat-number{display:block;font-size:1.8rem;font-weight:700;color:var(--primary-cyan);margin-bottom:5px}.stat-label{font-size:.9rem;color:var(--dark-gray)}.filter-section{display:flex;gap:20px;align-items:center;margin-bottom:25px;padding:15px;background:var(--light-gray);border-radius:10px;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-weight:600;color:var(--dark-gray)}.filter-group select{padding:8px 12px;border:2px solid var(--secondary-cyan);border-radius:8px;background:var(--white);color:var(--dark-gray);font-size:.9rem}.clear-history-btn{background:var(--danger);color:var(--white);border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;margin-left:auto}.clear-history-btn:hover:not(:disabled){background:#c82333;transform:translateY(-2px)}.clear-history-btn:disabled{background:#ccc;cursor:not-allowed}.history-list h3{color:var(--primary-cyan);margin-bottom:15px;font-size:1.2rem}.no-history{text-align:center;padding:40px;color:var(--dark-gray);font-size:1.1rem}.history-table{border:2px solid var(--secondary-cyan);border-radius:10px;overflow:hidden;margin:0 auto;width:100%}.table-header{display:grid;grid-template-columns:140px 120px 80px 80px 80px 80px 80px 60px;background:var(--primary-cyan);color:var(--white);font-weight:700;padding:15px 10px;font-size:.9rem;text-align:center;justify-items:center;align-items:center}.table-row{display:grid;grid-template-columns:140px 120px 80px 80px 80px 80px 80px 60px;padding:12px 10px;border-bottom:1px solid var(--secondary-cyan);font-size:.85rem;text-align:center;justify-items:center;align-items:center}.table-row:nth-child(2n){background:var(--light-gray)}.table-row:hover{background:var(--light-blue)}.date-cell{font-size:.8rem;color:var(--dark-gray);text-align:center}.mode-cell{font-weight:600;color:var(--primary-cyan);text-align:center}.score-cell,.accuracy-cell,.wpm-cell{text-align:center;font-weight:600}.result-cell{text-align:center;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:600}.result-cell.completed{background:var(--success);color:var(--white)}.result-cell.timeout{background:var(--warning);color:var(--white)}.result-cell.quit{background:var(--danger);color:var(--white)}.action-cell{text-align:center;display:flex;justify-content:center;align-items:center}.no-rating{text-align:center;color:var(--dark-gray);opacity:.6}.delete-record-btn{background:var(--danger);color:var(--white);border:none;border-radius:50%;width:32px;height:32px;min-width:32px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.delete-record-btn:hover{background:#c82333;transform:scale(1.1)}.history-btn{background:var(--accent-cyan);color:var(--white);border:none;padding:12px 20px;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.history-btn:hover{background:var(--primary-cyan);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.contact-btn{background:linear-gradient(135deg,var(--secondary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;padding:12px 20px;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px;margin-left:15px}.contact-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.menu-actions{margin-top:15px;display:flex;justify-content:center;align-items:center}.contact-section{max-width:700px;margin:30px auto;padding:20px;background:var(--white);border-radius:var(--border-radius-xl);box-shadow:0 10px 30px var(--shadow);border:2px solid var(--secondary-cyan);text-align:center;animation:fadeIn .5s ease-out}.contact-main-btn{background:linear-gradient(135deg,var(--secondary-cyan) 0%,var(--accent-cyan) 100%);color:var(--white);border:none;padding:15px 30px;border-radius:var(--border-radius-md);cursor:pointer;font-size:1.1rem;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:10px;margin:0 auto;min-width:180px;justify-content:center}.contact-main-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-2px);box-shadow:0 5px 15px var(--shadow)}@media(max-width:768px){.history-modal{width:95%;max-height:95vh}.stats-grid{grid-template-columns:repeat(2,1fr)}.filter-section{flex-direction:column;align-items:stretch}.table-header,.table-row{grid-template-columns:100px 80px 60px 60px 60px 60px 60px 40px;font-size:.75rem}.date-cell{font-size:.7rem}}.result-actions{display:flex;flex-direction:column;gap:20px;margin-top:40px;align-items:center;justify-content:center;width:100%}.share-btn{background:linear-gradient(135deg,#000,#333);color:#fff;border:none;padding:0;border-radius:16px;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px 32px #0000004d;width:280px;max-width:90vw;overflow:hidden;position:relative}.share-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.share-btn:hover:before{left:100%}.share-btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #0006}.share-btn:active{transform:translateY(-2px) scale(.98)}.share-btn.sharing{background:linear-gradient(135deg,#1da1f2,#0d8bd9);animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 8px 32px #1da1f24d}50%{box-shadow:0 8px 32px #1da1f299}}.share-btn:disabled{cursor:not-allowed}.share-btn-content{display:flex;align-items:center;padding:12px 32px;gap:12px;font-size:1.1rem;font-weight:600}.share-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;flex-shrink:0}.x-logo{width:18px;height:18px;fill:#fff}.loading-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.share-text{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.share-main{font-size:18px;font-weight:700;line-height:1.2;margin-bottom:2px}.share-sub{font-size:13px;font-weight:400;opacity:.8;line-height:1}.restart-btn{background:linear-gradient(135deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);color:#fff;border:none;padding:16px 32px;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px 32px var(--shadow);width:280px;max-width:90vw;display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}.restart-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}.restart-btn:hover:before{left:100%}.restart-btn:hover{background:linear-gradient(135deg,var(--accent-cyan) 0%,var(--primary-cyan) 100%);transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px var(--shadow)}.restart-btn:active{transform:translateY(-2px) scale(.98);box-shadow:0 4px 20px var(--shadow)}.restart-icon{font-size:16px;font-weight:700}@media(min-width:768px){.result-actions{flex-direction:column;align-items:center;justify-content:center;gap:20px;max-width:400px;margin:40px auto 0}}.notification-banner{background:linear-gradient(135deg,#f0f8ffcc,#e6f5ffe6);border:1px solid rgba(59,130,246,.15);border-radius:12px;max-width:700px;margin:20px auto;padding:12px 16px;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d;backdrop-filter:blur(10px);transition:all .3s ease;font-size:13px}.notification-banner:hover{background:linear-gradient(135deg,#f0f8fff2,#e6f5ff);box-shadow:0 2px 8px #00000014}.notification-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.notification-title{font-size:14px;font-weight:600;color:#374151}.notification-content{display:flex;flex-direction:column;gap:6px;flex:1;max-height:200px;overflow-y:auto;padding-right:4px}.notification-content::-webkit-scrollbar{width:6px}.notification-content::-webkit-scrollbar-track{background:#3b82f61a;border-radius:3px}.notification-content::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:3px}.notification-content::-webkit-scrollbar-thumb:hover{background:#3b82f680}.notification-item{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid rgba(59,130,246,.08);opacity:.6}.notification-item.new{opacity:1;font-weight:500}.notification-item:last-child{border-bottom:none}.notification-icon{font-size:14px;opacity:.8}.notification-date{font-size:11px;color:#6b7280;font-weight:500;min-width:60px;margin-top:1px}.notification-text{color:#374151;font-weight:400;line-height:1.4;flex:1}.notification-read-btn{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:4px;color:#3b82f6;cursor:pointer;font-size:10px;padding:2px 6px;transition:all .2s ease;margin-left:8px}.notification-read-btn:hover{background:#3b82f626;border-color:#3b82f64d}.notification-close-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;font-size:16px;font-weight:700;padding:4px 6px;border-radius:4px;transition:all .2s ease;margin-left:8px;line-height:1}.notification-close-btn:hover{background:#6b72801a;color:#374151}.rating-display{background:linear-gradient(135deg,var(--white) 0%,var(--light-blue) 100%);border:2px solid var(--secondary-cyan);border-radius:15px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:15px;box-shadow:0 6px 20px var(--shadow);transition:all .3s ease;position:relative;overflow:hidden}.rating-display:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,191,255,.1),transparent);transition:left .8s}.rating-display.rating-animated:before{left:100%}.rating-display:hover{border-color:var(--primary-cyan);transform:translateY(-2px);box-shadow:0 8px 25px var(--shadow)}.rating-display-tiny{padding:4px 6px;gap:4px;min-width:60px;font-size:.75rem}.rating-simple-tiny{padding:2px 4px;font-size:.7rem;border-radius:6px;gap:2px}.rating-simple-small{padding:3px 6px;font-size:.8rem;border-radius:8px;gap:3px}.rating-simple-normal{padding:4px 8px;font-size:.9rem;border-radius:10px;gap:4px}.rating-simple-large{padding:6px 12px;font-size:1.1rem;border-radius:14px;gap:6px}.rating-display-small{padding:12px;gap:8px;min-width:120px}.rating-display-normal{padding:20px;gap:15px;min-width:200px}.rating-display-large{padding:25px;gap:20px;min-width:250px}.rating-main{text-align:center;position:relative}.rating-number{font-size:2.5rem;font-weight:700;color:var(--primary-cyan);display:flex;align-items:center;justify-content:center;gap:8px;text-shadow:1px 1px 3px var(--shadow)}.rating-display-tiny .rating-number{font-size:1rem}.rating-display-small .rating-number{font-size:1.8rem}.rating-display-large .rating-number{font-size:3rem}.rating-label{font-size:.9rem;color:var(--dark-gray);opacity:.8;margin-top:5px;font-weight:500}.rating-change{font-size:1.2rem;font-weight:700;padding:4px 8px;border-radius:6px;margin-left:8px;display:inline-flex;align-items:center;transition:all .3s ease}.rating-change-positive{background:#28a7451a;color:var(--success);border:1px solid var(--success)}.rating-change-negative{background:#dc35451a;color:var(--danger);border:1px solid var(--danger)}.rating-change-animated{animation:ratingPulse 2s ease-in-out}@keyframes ratingPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.rating-rank{display:flex;justify-content:center;width:100%}.rank-badge{display:flex;flex-direction:column;align-items:center;padding:12px 20px;border-radius:12px;color:var(--white);font-weight:700;box-shadow:0 4px 15px #0003;text-shadow:1px 1px 2px rgba(0,0,0,.3);min-width:120px;transition:all .3s ease;border:2px solid rgba(255,255,255,.3)}.rank-badge:hover{transform:scale(1.05);box-shadow:0 6px 20px #0000004d}.rank-name{font-size:1rem;margin-bottom:2px}.rank-tier{font-size:.8rem;opacity:.9}.rating-display-tiny .rank-badge{padding:2px 4px;min-width:20px}.rating-display-tiny .rank-name{font-size:.6rem}.rating-display-small .rank-badge{padding:8px 12px;min-width:80px}.rating-display-small .rank-name{font-size:.8rem}.rating-display-small .rank-tier{font-size:.7rem}.rating-progress{width:100%;background:#ffffff80;border-radius:10px;padding:15px;border:1px solid var(--secondary-cyan)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem;color:var(--dark-gray)}.points-needed{font-weight:700;color:var(--primary-cyan)}.progress-bar-container{width:100%;height:8px;background:#00bfff33;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-cyan) 0%,var(--accent-cyan) 100%);border-radius:4px;transition:width .5s ease-in-out;position:relative}.progress-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressShimmer 2s infinite}@keyframes progressShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.next-rank-name{text-align:center;font-size:.8rem;color:var(--accent-cyan);font-weight:600}.rating-stats{background:var(--white);border:2px solid var(--secondary-cyan);border-radius:12px;padding:20px;margin-top:15px}.rating-stats .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:15px}.rating-stats .stat-item{text-align:center;padding:12px;background:var(--light-blue);border-radius:8px;border:1px solid var(--secondary-cyan)}.rating-stats .stat-number{font-size:1.4rem;font-weight:700;color:var(--primary-cyan);display:block;margin-bottom:5px}.rating-stats .stat-label{font-size:.8rem;color:var(--dark-gray);opacity:.8}.rating-graph{background:var(--white);border:2px solid var(--secondary-cyan);border-radius:10px;padding:15px;position:relative;margin-top:15px}.rating-graph-empty{display:flex;align-items:center;justify-content:center;color:var(--dark-gray);opacity:.7;font-style:italic}.rating-range{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;justify-content:space-between;height:80%;font-size:.7rem;color:var(--dark-gray)}.max-rating,.min-rating{background:var(--white);padding:2px 4px;border-radius:3px;border:1px solid var(--secondary-cyan)}.rating-cell{text-align:center;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:2px}.rating-value{color:var(--primary-cyan);font-size:2rem}.rating-change-small{font-size:.7rem;padding:1px 4px;border-radius:3px}.rating-change-small.positive{background:#28a7451a;color:var(--success)}.rating-change-small.negative{background:#dc35451a;color:var(--danger)}.result-rating-section{margin:30px 0;padding:25px;background:linear-gradient(135deg,var(--light-blue) 0%,var(--white) 100%);border-radius:15px;border:2px solid var(--secondary-cyan)}.result-rating-section h3{color:var(--primary-cyan);margin-bottom:20px;font-size:1.4rem;text-align:center}@media(max-width:768px){.rating-display{padding:15px;gap:10px}.rating-number{font-size:2rem}.rating-display-small .rating-number{font-size:1.5rem}.rating-progress{padding:12px}.rank-badge{padding:10px 15px;min-width:100px}.rating-stats .stats-grid{grid-template-columns:repeat(2,1fr)}.result-rating-section{padding:20px;margin:20px 0}}@media(max-width:480px){.rating-display{padding:12px;gap:8px}.rating-number{font-size:1.8rem}.rank-badge{padding:8px 12px;min-width:80px}.rank-name{font-size:.8rem}.rank-tier{font-size:.7rem}.rating-stats .stats-grid{grid-template-columns:1fr 1fr;gap:10px}.result-rating-section{padding:15px}.sound-toggle-btn{width:45px;height:45px;bottom:70px;right:15px;font-size:1.3rem}.settings-gear-btn{width:45px;height:45px;bottom:15px;right:15px;font-size:1.3rem}.settings-modal{width:95%;margin:20px}.settings-header,.settings-content{padding:15px 20px}.volume-label{flex-direction:column;align-items:flex-start;gap:8px}.volume-control-group{width:100%}}@media(max-width:768px){.notification-banner{margin:15px 12px;padding:10px 12px;font-size:12px}.notification-title{font-size:13px}.notification-text{font-size:12px}.notification-date{font-size:10px;min-width:55px}.notification-icon{font-size:12px}.notification-read-btn{font-size:9px;padding:1px 4px}.notification-close-btn{font-size:14px;padding:2px 4px}}.notification-banner{animation:slideInFromTop .4s ease-out}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.simple-rating{display:inline-flex;align-items:center;gap:2px;padding:1px 2px;font-weight:600}.simple-rating .rating-value{font-size:1rem;font-weight:inherit}.simple-rating .rating-change{font-size:.75em;font-weight:400;margin-left:2px;opacity:.9}.simple-rating .rating-change.positive{color:#4caf50}.simple-rating .rating-change.negative{color:#f44336}.rating-simple-tiny{padding:0;font-size:.7rem;gap:1px}.rating-simple-tiny .rating-change{font-size:1.5em;margin-left:1px}.rating-simple-small{padding:1px;font-size:.8rem;gap:2px}.rating-simple-normal{padding:1px 2px;font-size:.9rem;gap:2px}.rating-simple-large{padding:2px 3px;font-size:1.1rem;gap:3px}.rating-simple-large .rating-change{font-size:.7em;margin-left:2px}.site-links-carousel{max-width:700px;margin:30px auto;overflow:hidden;padding:10px 0}.site-links-track{display:flex;gap:30px;animation:scroll-left 20s linear infinite;width:fit-content}.site-links-track:hover{animation-play-state:paused}@keyframes scroll-left{0%{transform:translate(0)}to{transform:translate(-1050px)}}.site-link{display:block;text-decoration:none;transition:all .3s ease;border-radius:12px;overflow:hidden;flex-shrink:0}.site-link:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00bfff33}.site-image{width:320px;height:auto;display:block;transition:all .3s ease;object-fit:contain}.site-link:hover .site-image{transform:scale(1.02)}@media(max-width:768px){.site-links-carousel{margin:20px 0}.site-links-track{gap:20px}.site-image{width:280px}}@media(max-width:480px){.site-links-track{gap:15px;animation-duration:15s}.site-image{width:240px}.sound-toggle-btn{width:45px;height:45px;bottom:70px;right:15px;font-size:1.3rem}.settings-gear-btn,.feedback-button{width:45px;height:45px;font-size:1.3rem;bottom:15px}.settings-gear-btn{right:15px}.feedback-button{left:15px}.modal-overlay{padding:10px}.modal-content{margin:0;max-height:95vh}.modal-header{padding:15px 15px 0}.modal-header h2{font-size:1.3rem}.form-description{padding:0 15px;font-size:14px}form{padding:0 15px 15px}.form-input,.form-textarea,.form-select{font-size:16px}.success-modal{padding:30px 15px}.checkmark{width:50px;height:50px;font-size:25px}.close-btn{font-size:20px}.settings-modal{width:95%;max-height:90vh}.settings-header{padding:15px}.settings-header h3{font-size:1.3rem}.settings-content{padding:15px}.setting-section{padding:12px;margin-bottom:20px}.toggle-btn{padding:6px 12px;min-width:50px;font-size:14px}}.loading-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(5px)}.loading-overlay .loading-spinner{width:50px;height:50px;border:4px solid var(--secondary-cyan);border-top:4px solid var(--primary-cyan);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-text{font-size:1.2rem;color:var(--primary-cyan);font-weight:600}.bookmark-manager-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1200}.bookmark-manager{width:90%;max-width:640px;background:#fff;border-radius:8px;box-shadow:0 10px 30px #0003;overflow:hidden}.bm-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #eee}.bm-close{background:transparent;border:none;font-size:20px;cursor:pointer}.bm-loading{padding:20px;text-align:center;color:#666}.bm-list{max-height:60vh;overflow:auto}.bm-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #f3f3f3}.bm-text{flex:1}.bm-english{font-weight:700}.bm-japanese{color:#666;font-size:.9em}.bm-actions{margin-left:12px}.bm-delete{background:#ef4444;color:#fff;border:none;padding:6px 10px;border-radius:6px;cursor:pointer}.bm-empty{padding:20px;text-align:center;color:#666}.rc-perspective{perspective:1000px;margin-bottom:24px}.rc-perspective--large{margin:0 auto 24px;max-width:460px}.rc{position:relative;aspect-ratio:16 / 9;border-radius:16px;user-select:none;cursor:grab;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.22,1,.36,1),box-shadow .4s ease;will-change:transform;-webkit-tap-highlight-color:transparent;font-family:Verdana,Geneva,sans-serif}.rc--active{cursor:grabbing;transition:none}.rc__face{position:absolute;inset:0;border-radius:inherit;overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden}.rc__face--back{transform:rotateY(180deg)}.rc--guest{background:linear-gradient(135deg,#87ceeb,#5dade2,#87ceeb) padding-box,linear-gradient(135deg,#fff,#f0f9ff,#fff) border-box;border:2.5px solid transparent;color:#fff;box-shadow:0 0 24px #5dade24d,0 0 48px #ffffff14,0 6px 24px #5dade226}.rc--guest.rc--active{box-shadow:0 0 36px #5dade273,0 0 72px #ffffff26,0 12px 36px #5dade238}.rc--guest .rc__stat-value{color:#fff}.rc--guest .rc__logo-text{color:#ffffffe6}.rc--guest .rc__stat-label{color:#ffffff8c}.rc--logged-in{background:linear-gradient(135deg,#5dade2,#3498db,#5dade2) padding-box,linear-gradient(135deg,#fff,#e3f2fd,#fff) border-box;border:2.5px solid transparent;color:#fff;box-shadow:0 0 24px #3498db4d,0 0 48px #ffffff14,0 6px 24px #3498db2e}.rc--logged-in.rc--active{box-shadow:0 0 36px #3498db73,0 0 72px #ffffff26,0 12px 36px #3498db40}.rc--logged-in .rc__stat-value,.rc--logged-in .rc__logo-text{color:#fff}.rc--logged-in .rc__stat-label{color:#ffffff8c}.rc--premium{background:linear-gradient(135deg,#1a2744,#1e3a5f,#264f7a) padding-box,linear-gradient(135deg,gold,orange,gold) border-box;border:2.5px solid transparent;color:#e8f0f8;box-shadow:0 0 20px #ffd70026,0 0 40px #ffd7000f,0 6px 24px #0003}.rc--premium.rc--active{box-shadow:0 0 30px #ffd70040,0 0 60px #ffd7001a,0 12px 36px #0000004d}.rc--premium .rc__stat-value{color:#fff}.rc--premium .rc__logo-text{color:gold}.rc--premium .rc__stat-label{color:#ffffff80}.rc__pattern{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(ellipse at 20% 70%,rgba(255,255,255,.12) 0%,transparent 55%),radial-gradient(ellipse at 80% 30%,rgba(93,173,226,.1) 0%,transparent 50%);opacity:1}.rc--premium .rc__pattern{background-image:radial-gradient(ellipse at 20% 80%,rgba(255,215,0,.08) 0%,transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(255,165,0,.06) 0%,transparent 50%)}.rc__holo{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:2;opacity:0;transition:opacity .3s ease;mix-blend-mode:overlay}.rc__glare{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:3;opacity:0;transition:opacity .4s ease,background .15s ease}.rc__edge{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;border:1px solid rgba(255,255,255,.2)}.rc--active .rc__edge{border-color:#fff6}.rc__content{position:relative;z-index:4;padding:14px 18px;display:flex;flex-direction:column;gap:10px;height:100%;box-sizing:border-box;justify-content:center}.rc__header{text-align:left;width:100%}.rc__logo-text{font-size:.95rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.rc__stats{display:flex;flex-direction:row;justify-content:space-around;width:100%}.rc__stats--detailed{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 0;justify-items:center}.rc__stat{display:flex;flex-direction:column;align-items:center;gap:2px}.rc__stat-label{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.rc__stat-value{font-size:1.4rem;font-weight:800;font-family:Courier New,Menlo,monospace;letter-spacing:.02em;display:flex;align-items:center;gap:6px;line-height:1.2}.rc__stat-value--sm{font-size:1rem;font-weight:700}.rc--detailed .rc__stat-value{font-size:1.1rem}.rc--detailed .rc__stat-value--sm{font-size:.85rem}.rc--detailed .rc__stat-label{font-size:.5rem}.rc__face--back .rc__stat-value{font-size:1.1rem}.rc__face--back .rc__stat-label{font-size:.5rem}.rc__rank-dot{display:inline-block;width:9px;height:9px;border-radius:50%;border:2px solid rgba(255,255,255,.5);flex-shrink:0;box-shadow:0 0 6px #ffffff4d}.rc--premium .rc__rank-dot{border-color:#ffffff80;box-shadow:0 0 6px #ffd7004d}.rc__footer{text-align:right;width:100%}.rc__flip-btn{position:absolute;right:12px;top:10px;z-index:5;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.4);border-radius:50%;color:#fff;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.rc__flip-btn:hover{background:#ffffff4d;border-color:#fff9}.rc--premium .rc__flip-btn{background:#ffd70014;border-color:#ffd7004d;color:#fffc}.rc--premium .rc__flip-btn:hover{background:#ffd70026;color:#fff}.rc__premium-ribbon{position:absolute;top:16px;right:-32px;background:linear-gradient(90deg,gold,orange);color:#1a1a2e;font-size:.5rem;font-weight:900;letter-spacing:.18em;padding:3px 40px;transform:rotate(45deg);z-index:5;box-shadow:0 2px 6px #0000004d}.rc-perspective--large .rc{border-radius:20px}.rc-perspective--large .rc__content{padding:20px 28px;gap:12px}.rc-perspective--large .rc__logo-text{font-size:1.05rem}.rc-perspective--large .rc--detailed .rc__stat-value{font-size:1.3rem}.rc-perspective--large .rc--detailed .rc__stat-label{font-size:.55rem}.rc-perspective--large .rc__face--back .rc__stat-value{font-size:1.3rem}.rc-perspective--large .rc__face--back .rc__stat-label{font-size:.55rem}.record-card-detail{padding:30px 20px;max-width:460px;margin:0 auto}.record-card-detail__title{font-size:1.4rem;font-weight:700;color:var(--primary-cyan);text-align:center;margin-bottom:24px}@media(prefers-reduced-motion:reduce){.rc{transition:none!important}}@media(max-width:480px){.rc__content{padding:12px 14px;gap:8px}.rc__logo-text{font-size:.8rem}.rc__stat-value{font-size:1.15rem}.rc__stat-value--sm{font-size:.8rem}.rc--detailed .rc__stat-value{font-size:.95rem}.rc--detailed .rc__stat-label{font-size:.45rem}.rc__face--back .rc__stat-value{font-size:.95rem}.rc__face--back .rc__stat-label{font-size:.45rem}.rc-perspective--large .rc__content{padding:14px 18px;gap:10px}.rc-perspective--large .rc--detailed .rc__stat-value,.rc-perspective--large .rc__face--back .rc__stat-value{font-size:1.05rem}.rc__flip-btn{width:28px;height:28px}.rc__flip-btn svg{width:14px;height:14px}}.rc-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1200;padding:24px;backdrop-filter:blur(6px);animation:rcFadeIn .3s ease-out}.rc-modal{position:relative;width:100%;max-width:900px;animation:rcScaleIn .3s ease-out}.rc-modal .rc-perspective--large{max-width:100%}.rc-modal .rc__logo-text{font-size:1.3rem}.rc-modal .rc__stat-value{font-size:2rem}.rc-modal .rc__stat-value--sm{font-size:1.3rem}.rc-modal .rc__stat-label{font-size:.7rem}.rc-modal .rc--detailed .rc__stat-value{font-size:1.8rem}.rc-modal .rc--detailed .rc__stat-label{font-size:.65rem}.rc-modal .rc__content{padding:28px 40px;gap:16px}.rc-modal .rc__stats--detailed{gap:16px 0}.rc-modal-close{position:absolute;top:-40px;right:0;z-index:10;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ffffffd9;font-size:.85rem;transition:all .2s ease}.rc-modal-close:hover{background:#ffffff40;color:#fff}@keyframes rcFadeIn{0%{opacity:0}to{opacity:1}}@keyframes rcScaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.global-toast-container{position:fixed;right:16px;bottom:24px;display:flex;flex-direction:column;gap:8px;z-index:10000}.global-toast{min-width:240px;max-width:420px;background:#222;color:#fff;padding:12px 14px;border-radius:8px;box-shadow:0 6px 18px #00000040;display:flex;align-items:center;justify-content:space-between}.global-toast.info{background:#333}.global-toast.success{background:#1e9b43}.global-toast.warning{background:#e09b2c;color:#111}.global-toast.error{background:#d33}.global-toast-message{flex:1;margin-right:8px}.global-toast-close{background:transparent;border:none;color:inherit;cursor:pointer;font-size:14px}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-modal-content{background:#fff;border-radius:16px;padding:32px;max-width:450px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:32px;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.auth-modal-close:hover{background:#f0f0f0;color:#333}.auth-modal-header{text-align:center;margin-bottom:32px}.auth-modal-header h2{font-size:24px;font-weight:700;background:linear-gradient(135deg,#00bfff,#5dade2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form-group{display:flex;flex-direction:column;gap:8px}.auth-form-group label{font-size:14px;font-weight:600;color:#555}.auth-form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .2s}.auth-form-group input:focus{outline:none;border-color:#00bfff;box-shadow:0 0 0 3px #00bfff1a}.auth-form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.auth-error{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;font-size:14px;border-left:4px solid #c62828}.auth-success-message{text-align:center;padding:24px}.auth-success-message p{margin:8px 0;color:#555}.auth-success-message p:first-child{font-size:18px;font-weight:600;color:#00bfff}.auth-btn{width:100%;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn-primary{background:linear-gradient(135deg,#00bfff,#5dade2);color:#fff}.auth-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#09c,#4a9fcc);transform:translateY(-1px);box-shadow:0 4px 12px #00bfff66}.auth-btn-google{background:#fff;color:#333;border:2px solid #e0e0e0}.auth-btn-google:hover:not(:disabled){background:#f8f8f8;border-color:#d0d0d0;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.google-icon{font-weight:700;font-size:18px;background:linear-gradient(to right,#4285f4,#ea4335,#fbbc05,#34a853);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-divider{display:flex;align-items:center;margin:24px 0;color:#999;font-size:14px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.auth-divider span{padding:0 16px}.auth-links{display:flex;flex-direction:column;gap:12px;margin-top:24px;align-items:center}.auth-link{background:none;border:none;color:#00bfff;font-size:14px;cursor:pointer;text-decoration:none;transition:all .2s}.auth-link:hover{color:#5dade2;text-decoration:underline}@media(max-width:768px){.auth-modal-content{padding:24px;width:95%}.auth-modal-header h2{font-size:20px}.auth-btn{padding:12px 20px;font-size:15px}}.user-menu-container{position:fixed;top:20px;right:20px;z-index:1000}.login-btn{display:flex;align-items:center;gap:8px;padding:10px 30px;background:linear-gradient(135deg,#00bfff,#5dade2);color:#fff;border:none;border-radius:0;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #00bfff4d;min-width:100px}.login-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00bfff66}.login-btn:active{transform:translateY(0)}.login-btn-wrapper{position:relative;display:inline-block}.login-tooltip{position:absolute;top:50%;right:calc(100% + 12px);transform:translateY(-50%);background:#fff;color:#013a63;padding:10px 14px;border-radius:8px;font-size:13px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s;z-index:1100;pointer-events:none;box-shadow:0 6px 18px #013a631f;border:1px solid rgba(0,183,255,.22)}.login-tooltip:before{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#fff;margin-left:1px}.login-tooltip div{margin:2px 0}.login-btn-wrapper:hover .login-tooltip{opacity:1;visibility:visible;transform:translateY(-50%) translate(-4px);pointer-events:auto}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:8px 16px 8px 8px;background:#fff;border:2px solid #e0e0e0;border-radius:0;cursor:pointer;transition:all .2s;font-size:15px;font-weight:600;color:#333}.user-menu-trigger:hover{border-color:#00bfff;box-shadow:0 2px 8px #00bfff33}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#00bfff,#5dade2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-backdrop{position:fixed;inset:0;z-index:999}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:280px;z-index:1001;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:20px;display:flex;align-items:center;gap:12px}.user-avatar-large{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#00bfff,#5dade2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:20px;overflow:hidden;flex-shrink:0}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.user-info{flex:1;min-width:0}.user-info-name{font-weight:600;font-size:16px;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info-email{font-size:13px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.user-menu-divider{height:1px;background:#e0e0e0;margin:0 12px}.user-menu-item{width:100%;padding:14px 20px;background:none;border:none;text-align:left;cursor:pointer;font-size:15px;color:#333;display:flex;align-items:center;gap:10px;transition:background .2s}.user-menu-item:hover{background:#f5f5f5}.user-menu-signout{color:#f44336;border-radius:0 0 12px 12px}.user-menu-signout:hover{background:#ffebee}@media(max-width:768px){.user-name{display:none}.user-menu-trigger{padding:8px}.user-menu-dropdown{right:-10px;min-width:260px}.login-btn{padding:10px 16px;font-size:14px}.login-btn span{display:none}}.stats-view{width:100%;height:100%;padding:24px 16px 60px}.stats-inner{max-width:600px;margin:0 auto;padding-bottom:24px}.stats-blurred{filter:blur(6px);opacity:.6;pointer-events:none;user-select:none}.stats-panel{position:relative;background:#fff;border-radius:16px;border:1px solid rgba(135,206,235,.25);padding:20px;margin-bottom:16px}.stats-panel h3{font-size:1.05rem;font-weight:700;color:var(--dark-gray);margin:0 0 16px;text-align:center}.stats-panel-header{position:relative;text-align:center;margin-bottom:16px}.stats-panel-header h3{margin:0}.stats-panel-header .stats-tab-toggle{position:absolute;right:0;top:50%;transform:translateY(-50%)}.stats-panel-header .stats-select{position:absolute;left:0;top:50%;transform:translateY(-50%)}.stats-select{display:block;width:100%;max-width:200px;margin:0 0 16px;padding:8px 32px 8px 12px;font-size:.85rem;font-weight:500;color:var(--dark-gray);background:#fff;border:1px solid rgba(135,206,235,.35);border-radius:8px;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232C3E50' stroke-width='1.5' fill='none' opacity='0.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .2s}.stats-select:focus{outline:none;border-color:var(--primary-cyan)}.year-selector{display:flex;align-items:center;gap:8px}.year-selector button{background:none;border:1px solid rgba(135,206,235,.3);color:var(--primary-cyan);width:28px;height:28px;border-radius:6px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.year-selector button:hover:not(:disabled){background:#00bfff14}.year-selector button:disabled{opacity:.3;cursor:default}.year-selector span{font-size:.85rem;font-weight:600;color:var(--dark-gray);min-width:40px;text-align:center}.heatmap-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px}.heatmap-wrapper{min-width:700px}.heatmap-months{display:grid;grid-template-columns:repeat(53,1fr);margin-bottom:4px;font-size:10px;color:#2c3e5066}.heatmap-grid{display:flex;gap:2px}.heatmap-week{display:flex;flex-direction:column;gap:2px;animation:heatmapFadeIn .3s ease-out both}@keyframes heatmapFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.heatmap-cell{width:11px;height:11px;border-radius:2px;cursor:pointer;transition:opacity .15s}.heatmap-cell:hover{opacity:.75;outline:1px solid rgba(44,62,80,.2)}.heatmap-cell.empty{background:transparent}.stats-tab-toggle{display:flex;gap:2px;background:#87ceeb1a;padding:2px;border-radius:6px}.stats-tab-toggle button{padding:4px 12px;border:none;background:transparent;border-radius:5px;font-size:.75rem;font-weight:500;color:#2c3e5080;cursor:pointer;transition:all .2s}.stats-tab-toggle button.active{background:#fff;color:var(--accent-cyan);font-weight:600;box-shadow:0 1px 3px #0000000f}.chart-container{width:100%;position:relative}.chart-container canvas{display:block;width:100%}.donut-layout{display:flex;align-items:center;gap:20px;overflow:hidden}.donut-center{flex:1;display:flex;justify-content:center}.donut-center canvas{display:block;width:200px!important;height:200px!important}.donut-legend{flex:1;display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--dark-gray)}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-label{flex:1}.legend-value{font-weight:600;color:#2c3e5099}.stats-tooltip{position:absolute;transform:translate(-50%) translateY(-100%);background:#0b2035eb;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;white-space:nowrap;pointer-events:none;z-index:1000;margin-top:-8px;opacity:0;transition:opacity .12s}.stats-tooltip.tooltip-visible{opacity:1}@media(max-width:767px){.heatmap-cell{width:10px;height:10px}}@media(max-width:479px){.stats-view{padding:16px 12px 60px}.stats-panel{padding:14px}.donut-layout{flex-direction:column;gap:12px}.donut-legend{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:10px}}
