@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;900&family=Playfair+Display:wght@400;600;700;900&display=swap";.help-section{margin-bottom:32px}.help-section:last-child{margin-bottom:0}.help-section-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid rgba(102,126,234,.3)}.help-section-content{color:#ffffffe6;font-size:15px;line-height:1.8}.help-section-content p{margin:0 0 8px;padding-left:20px;position:relative}.help-section-content p:last-child{margin-bottom:0}.help-section-content p:before{content:"•";position:absolute;left:0;color:#667eeacc;font-weight:700}.faq-container{max-width:700px;margin:0 auto}.faq-intro{margin-bottom:24px;text-align:center}.faq-intro p{color:#fffc;font-size:15px;margin:0}.faq-list{display:flex;flex-direction:column;gap:12px}.faq-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;transition:all .3s ease}.faq-item:hover{background:#ffffff14;border-color:#fff3}.faq-item.expanded{background:#667eea1a;border-color:#667eea4d}.faq-question{width:100%;padding:20px 24px;border:none;background:transparent;color:#fff;font-size:16px;font-weight:500;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.faq-question:hover{padding-left:28px}.faq-icon{font-size:20px;color:#fff9;transition:transform .3s ease}.faq-item.expanded .faq-icon{transform:rotate(45deg)}.faq-answer{padding:0 24px 20px;animation:faqSlideDown .3s ease-out}@keyframes faqSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.faq-answer p{color:#fffc;font-size:14px;line-height:1.7;margin:0}.faq-footer{margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.faq-footer p{color:#fff9;font-size:14px;margin:0}@media (max-width: 768px){.faq-question{padding:16px 20px;font-size:15px}.faq-answer{padding:0 20px 16px}.faq-answer p{font-size:13px}}.shortcuts-container{max-width:700px;margin:0 auto}.shortcuts-intro{margin-bottom:32px;text-align:center}.shortcuts-intro p{color:#fffc;font-size:15px;margin:0}.shortcut-group{margin-bottom:32px;background:#ffffff08;border-radius:12px;padding:24px;border:1px solid rgba(255,255,255,.08)}.shortcut-group:last-child{margin-bottom:0}.shortcut-group-title{font-size:18px;font-weight:600;color:#fff;margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.shortcut-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:24px;padding:8px 0}.shortcut-keys{display:flex;align-items:center;gap:6px;min-width:140px}.shortcut-key{display:inline-block;padding:4px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:13px;font-weight:500;font-family:SF Mono,Monaco,Consolas,monospace;box-shadow:0 2px 4px #0003}.shortcut-plus{color:#ffffff80;font-size:14px;margin:0 2px}.shortcut-description{flex:1;color:#fffc;font-size:14px}.shortcuts-note{margin-top:32px;padding:16px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;text-align:center}.shortcuts-note p{color:#ffc107e6;font-size:13px;margin:0}@media (max-width: 768px){.shortcut-group{padding:20px}.shortcut-item{flex-direction:column;align-items:flex-start;gap:8px}.shortcut-keys{min-width:auto}.shortcut-description{font-size:13px}}.support-container{max-width:600px;margin:0 auto}.support-intro{margin-bottom:32px;text-align:center}.support-intro p{color:#fffc;font-size:15px;margin:0}.support-form{background:#ffffff0d;border-radius:12px;padding:32px;border:1px solid rgba(255,255,255,.1)}.form-group{margin-bottom:24px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:8px;color:#fff;font-size:14px;font-weight:500}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:15px;transition:all .2s ease;resize:vertical}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:#fff6}.form-input::placeholder,.form-textarea::placeholder{color:#fff6}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;background:#ffffff1a;border-color:#667eea80;box-shadow:0 0 0 3px #667eea1a}.form-select{cursor:pointer}.form-textarea{min-height:120px;font-family:inherit;line-height:1.5}.support-submit{width:100%;padding:14px 32px;margin-top:32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea4d}.support-submit:hover{transform:translateY(-2px);box-shadow:0 6px 30px #667eea66}.support-submit:active{transform:translateY(0)}.support-success{text-align:center;padding:60px 20px}.success-icon{width:80px;height:80px;margin:0 auto 24px;background:linear-gradient(135deg,#84fab0,#8fd3f4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff;box-shadow:0 10px 30px #84fab04d;animation:successPulse .5s ease-out}@keyframes successPulse{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.support-success h3{font-size:24px;font-weight:600;color:#fff;margin:0 0 12px}.support-success p{font-size:16px;color:#fffc;margin:0}.support-alternatives{margin-top:48px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1)}.support-alternatives h4{font-size:18px;font-weight:600;color:#fff;margin:0 0 20px;text-align:center}.support-links{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.support-link{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fffc;text-decoration:none;font-size:14px;transition:all .2s ease}.support-link:hover{background:#ffffff1a;border-color:#fff3;color:#fff;transform:translateY(-2px)}.support-link-icon{font-size:20px}@media (max-width: 768px){.support-form{padding:24px 20px}.support-links{flex-direction:column}.support-link{width:100%;justify-content:center}}.help-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:9500;display:flex;align-items:center;justify-content:center;animation:helpFadeIn .3s ease-out}@keyframes helpFadeIn{0%{opacity:0}to{opacity:1}}.help-menu-container{width:90%;max-width:900px;height:80%;max-height:700px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;border:2px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0000004d,0 0 100px #667eea1a;display:flex;flex-direction:column;overflow:hidden;animation:helpSlideIn .3s ease-out}@keyframes helpSlideIn{0%{transform:translateY(20px) scale(.95)}to{transform:translateY(0) scale(1)}}.help-menu-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid rgba(255,255,255,.1)}.help-menu-title{font-size:24px;font-weight:700;color:#fff;margin:0}.help-menu-close{width:40px;height:40px;border:none;background:#ffffff1a;color:#fff9;border-radius:50%;font-size:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.help-menu-close:hover{background:#fff3;color:#fff}.help-menu-tabs{display:flex;gap:8px;padding:0 32px;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.help-tab{padding:16px 24px;border:none;background:transparent;color:#fff9;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.help-tab:hover{color:#ffffffe6}.help-tab.active{color:#fff}.help-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px 3px 0 0}.help-menu-content{flex:1;overflow-y:auto;padding:32px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.help-menu-content::-webkit-scrollbar{width:8px}.help-menu-content::-webkit-scrollbar-track{background:transparent}.help-menu-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.help-menu-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.help-content{max-width:700px;margin:0 auto}.help-tutorial-restart{margin-top:48px;text-align:center;padding-top:32px;border-top:1px solid rgba(255,255,255,.1)}.help-button-primary{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea4d}.help-button-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px #667eea66}@media (max-width: 768px){.help-menu-container{width:100%;height:100%;max-width:none;max-height:none;border-radius:0}.help-menu-header{padding:20px}.help-menu-tabs{padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.help-tab{padding:12px 16px;font-size:14px;white-space:nowrap}.help-menu-content{padding:20px}}.tooltip-trigger{display:inline-block;position:relative}.tooltip{position:fixed;z-index:9000;pointer-events:all;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.tooltip-content{background:#14141ef2;color:#ffffffe6;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;max-width:250px;box-shadow:0 4px 20px #0000004d,0 0 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tooltip-dismiss{position:absolute;top:4px;right:4px;width:20px;height:20px;border:none;background:#ffffff1a;color:#ffffff80;border-radius:50%;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.tooltip-dismiss:hover{background:#fff3;color:#fffc}.tooltip:before{content:"";position:absolute;width:0;height:0;border:6px solid transparent}.tooltip-top:before{bottom:-12px;left:50%;transform:translate(-50%);border-top-color:#14141ef2}.tooltip-bottom:before{top:-12px;left:50%;transform:translate(-50%);border-bottom-color:#14141ef2}.tooltip-left:before{right:-12px;top:50%;transform:translateY(-50%);border-left-color:#14141ef2}.tooltip-right:before{left:-12px;top:50%;transform:translateY(-50%);border-right-color:#14141ef2}.tooltip-firsttime{animation:tooltipPulse 2s ease-in-out infinite}@keyframes tooltipPulse{0%,to{box-shadow:0 4px 20px #0000004d,0 0 0 1px #ffffff1a}50%{box-shadow:0 4px 30px #667eea66,0 0 0 1px #667eea4d}}@media (hover: none){.tooltip-trigger{cursor:pointer}.tooltip-content{padding:16px 20px;font-size:15px;max-width:300px}.tooltip-dismiss{width:28px;height:28px;font-size:16px}}.help-button{position:fixed;bottom:80px;right:20px;width:48px;height:48px;background:#1e1e28e6;border:2px solid rgba(255,255,255,.1);border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:1000;box-shadow:0 4px 12px #0000004d}.help-button:hover{background:#282832f2;color:#fff;border-color:#667eea4d;transform:translateY(-2px);box-shadow:0 6px 20px #0006}.help-button:active{transform:translateY(0)}.help-button svg{width:24px;height:24px}.help-button.first-time{animation:helpPulse 2s ease-in-out infinite}@keyframes helpPulse{0%,to{box-shadow:0 4px 12px #0000004d,0 0 #667eea66}50%{box-shadow:0 4px 12px #0000004d,0 0 0 12px #667eea00}}@media (max-width: 768px){.help-button{bottom:60px;right:16px;width:44px;height:44px}.help-button svg{width:22px;height:22px}}.tutorial-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10000;pointer-events:none}.tutorial-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000c;pointer-events:all}.tutorial-spotlight{position:absolute;background-color:transparent;border-radius:8px;box-shadow:0 0 0 9999px #000c,0 0 20px #ffffff4d inset;pointer-events:none;transition:all .3s ease-out}.tutorial-tooltip{position:absolute;background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;max-width:400px;box-shadow:0 10px 40px #00000080,0 0 60px #8a2be233;pointer-events:all;animation:tutorialFadeIn .3s ease-out}@keyframes tutorialFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutorial-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tutorial-title{font-size:20px;font-weight:700;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.tutorial-progress{font-size:14px;color:#fff9;font-weight:500}.tutorial-content{margin-bottom:20px}.tutorial-content p{font-size:15px;line-height:1.6;color:#ffffffe6;margin:0}.tutorial-actions{display:flex;gap:12px;justify-content:flex-end;margin-bottom:16px}.tutorial-button{padding:8px 20px;border-radius:6px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;outline:none}.tutorial-button:hover{transform:translateY(-2px)}.tutorial-button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.tutorial-button-primary:hover{box-shadow:0 6px 20px #667eea66}.tutorial-button-secondary{background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.2)}.tutorial-button-secondary:hover{background:#ffffff26;border-color:#ffffff4d}.tutorial-button-skip{background:transparent;color:#fff9;border:1px solid rgba(255,255,255,.2)}.tutorial-button-skip:hover{color:#fffc;border-color:#ffffff4d}.tutorial-dots{display:flex;gap:8px;justify-content:center}.tutorial-dot{width:8px;height:8px;border-radius:50%;background:#fff3;transition:all .3s ease}.tutorial-dot.active{background:#667eea;box-shadow:0 0 10px #667eea80}.tutorial-dot.completed{background:#667eea99}.tutorial-arrow{position:absolute;color:#667eea;animation:tutorialBounce 2s ease-in-out infinite;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(102,126,234,.4))}@keyframes tutorialBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.tutorial-position-top:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #16213e}.tutorial-position-bottom:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #1a1a2e}.tutorial-position-left:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:8px solid #16213e}.tutorial-position-right:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid #1a1a2e}@media (max-width: 768px){.tutorial-tooltip{max-width:calc(100vw - 40px);margin:0 20px}.tutorial-title{font-size:18px}.tutorial-content p{font-size:14px}.tutorial-button{padding:6px 16px;font-size:13px}}.onboarding-step{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;border:2px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0000004d,0 0 100px #667eea1a;padding:48px;height:100%;min-height:0;display:flex;flex-direction:column;position:relative;overflow:hidden;animation:onboardingSlideIn .5s ease-out}@keyframes onboardingSlideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.onboarding-character{position:absolute;bottom:0;right:40px;width:200px;height:300px;pointer-events:none;animation:characterFadeIn .8s ease-out .3s both}@keyframes characterFadeIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.onboarding-character-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 10px 40px rgba(0,0,0,.3))}.onboarding-content{flex:1;display:flex;flex-direction:column;max-width:600px;margin:0 auto;width:100%}.onboarding-image{margin-bottom:32px;text-align:center}.onboarding-image img{max-width:100%;max-height:200px;border-radius:12px;box-shadow:0 10px 30px #0000004d}.onboarding-title{font-size:32px;font-weight:700;color:#fff;margin:0 0 24px;text-align:center;text-shadow:0 2px 10px rgba(0,0,0,.3)}.onboarding-description{flex:1;display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:0 8px;min-height:0;width:100%}.onboarding-text{font-size:16px;line-height:1.8;color:#ffffffe6;width:100%;word-wrap:break-word;overflow-wrap:break-word}.onboarding-text p{margin:0 0 16px;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.onboarding-text p:last-child{margin-bottom:0}.onboarding-steps{display:flex;gap:12px;justify-content:center;margin:32px 0 24px}.onboarding-step-dot{width:12px;height:12px;border-radius:50%;background:#fff3;transition:all .3s ease;cursor:pointer}.onboarding-step-dot:hover{background:#ffffff4d}.onboarding-step-dot.active{width:32px;border-radius:6px;background:linear-gradient(90deg,#667eea,#764ba2)}.onboarding-step-dot.completed{background:#667eea99}.onboarding-actions{display:flex;gap:16px;justify-content:center}.onboarding-button{padding:12px 32px;border-radius:8px;font-size:16px;font-weight:600;border:none;cursor:pointer;transition:all .3s ease;outline:none;text-transform:none}.onboarding-button:hover{transform:translateY(-2px)}.onboarding-button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 20px #667eea4d;min-width:120px}.onboarding-button-primary:hover{box-shadow:0 6px 30px #667eea66}.onboarding-button-start{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 20px #f5576c4d}.onboarding-button-start:hover{box-shadow:0 6px 30px #f5576c66}.onboarding-button-secondary{background:#ffffff1a;color:#fffc;border:2px solid rgba(255,255,255,.2)}.onboarding-button-secondary:hover{background:#ffffff26;border-color:#ffffff4d}.onboarding-button-skip{background:transparent;color:#ffffff80;border:2px solid rgba(255,255,255,.2)}.onboarding-button-skip:hover{color:#ffffffb3;border-color:#ffffff4d}.onboarding-characters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;width:100%;padding:16px 0}.character-intro{text-align:center}.character-intro img{width:80px;height:80px;border-radius:50%;margin-bottom:8px;-o-object-fit:cover;object-fit:cover}.character-intro h4{font-size:16px;margin:0 0 4px;color:#fff}.character-intro p{font-size:12px;color:#ffffffb3;margin:0}.compatibility-example{text-align:center;margin:20px 0}.score-display{display:inline-flex;align-items:baseline;margin-bottom:12px}.score-number{font-size:48px;font-weight:700;color:#667eea}.score-label{font-size:24px;color:#667eea;margin-left:4px}.score-description{font-size:14px;color:#fffc;max-width:300px;margin:0 auto}.conversation-tips{background:#ffffff0d;border-radius:12px;padding:16px;margin-top:16px}.conversation-tips h4{font-size:16px;margin:0 0 12px;color:#fff}.conversation-tips ul{list-style:none;padding:0;margin:0}.conversation-tips li{position:relative;padding-left:20px;margin-bottom:8px;color:#fffc}.conversation-tips li:before{content:"•";position:absolute;left:0;color:#667eea}.property-features{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}.feature-tag{background:#667eea33;color:#667eea;padding:6px 16px;border-radius:20px;font-size:14px;border:1px solid rgba(102,126,234,.3)}.cost-info{background:#ffffff0d;border-radius:12px;padding:16px;margin:16px 0}.cost-item{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:15px}.cost-icon{font-size:20px}.cost-note{font-size:14px;color:#ffffffb3;text-align:center;margin-top:16px}.onboarding-checklist{background:#ffffff0d;border-radius:12px;padding:20px;margin-top:20px;text-align:left;max-width:300px;margin-left:auto;margin-right:auto}.onboarding-checklist label{display:flex;align-items:center;gap:12px;margin-bottom:12px;cursor:default}.onboarding-checklist label:last-child{margin-bottom:0}.onboarding-checklist input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:default}.onboarding-checklist span{color:#ffffffe6;font-size:14px}@media (max-width: 768px){.onboarding-step{padding:24px 16px}.onboarding-character{display:none}.onboarding-title{font-size:24px;word-wrap:break-word;overflow-wrap:break-word}.onboarding-text{font-size:14px}.onboarding-button{padding:10px 20px;font-size:14px;min-width:auto}.onboarding-actions{flex-wrap:wrap;gap:12px}.onboarding-characters-grid{grid-template-columns:repeat(2,1fr);gap:12px}.character-intro img{width:60px;height:60px}.character-intro h4{font-size:14px}.score-number{font-size:36px}.score-label{font-size:18px}.feature-tag{font-size:12px;padding:4px 12px}.cost-item{font-size:14px}.onboarding-checklist{padding:16px}}.onboarding-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:9999;display:flex;align-items:center;justify-content:center;animation:onboardingFadeIn .5s ease-out}@keyframes onboardingFadeIn{0%{opacity:0}to{opacity:1}}.onboarding-container{width:90%;max-width:800px;height:90%;max-height:600px;position:relative;display:flex;flex-direction:column}.onboarding-progress{position:absolute;bottom:-20px;left:0;right:0;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.onboarding-progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease-out;border-radius:2px}.onboarding-characters-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}.character-intro{text-align:center;padding:16px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.character-intro:hover{background:#ffffff14;transform:translateY(-2px)}.character-intro img{width:80px;height:80px;border-radius:50%;margin-bottom:8px;border:3px solid rgba(255,255,255,.2)}.character-intro h4{margin:0;font-size:16px;color:#fff;font-weight:600}.character-intro p{margin:4px 0 0;font-size:13px;color:#ffffffb3}.compatibility-example{display:flex;align-items:center;gap:24px;margin:24px 0;padding:20px;background:#667eea1a;border-radius:12px;border:1px solid rgba(102,126,234,.3)}.score-display{display:flex;align-items:baseline;min-width:80px}.score-number{font-size:48px;font-weight:700;color:#667eea;line-height:1}.score-label{font-size:24px;color:#667eeacc;margin-left:2px}.score-description{flex:1;margin:0;color:#fffc;font-size:14px;line-height:1.6}.conversation-tips{background:#ffffff0d;border-radius:12px;padding:20px;margin-top:20px}.conversation-tips h4{margin:0 0 12px;color:#fff;font-size:16px}.conversation-tips ul{margin:0;padding-left:24px;list-style:none}.conversation-tips li{position:relative;margin-bottom:8px;color:#fffc;font-size:14px}.conversation-tips li:before{content:"✓";position:absolute;left:-20px;color:#667eea;font-weight:700}.property-features{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.feature-tag{padding:6px 14px;background:#667eea33;border:1px solid rgba(102,126,234,.4);border-radius:20px;font-size:13px;color:#fff;font-weight:500}.cost-info{background:#ffffff0d;border-radius:12px;padding:20px;margin:20px 0}.cost-item{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:15px;color:#ffffffe6}.cost-item:last-child{margin-bottom:0}.cost-icon{font-size:20px;width:30px;text-align:center}.cost-note{margin-top:16px;font-size:13px;color:#ffffffb3;text-align:center}.onboarding-final{text-align:center}.onboarding-checklist{display:inline-flex;flex-direction:column;gap:12px;margin-top:24px;text-align:left}.onboarding-checklist label{display:flex;align-items:center;gap:12px;cursor:default}.onboarding-checklist input[type=checkbox]{width:20px;height:20px;accent-color:#667eea}.onboarding-checklist span{font-size:15px;color:#ffffffe6}@media (max-width: 768px){.onboarding-container{width:95%;height:auto;max-height:95vh;overflow-y:auto}.onboarding-characters-grid{grid-template-columns:repeat(2,1fr);gap:12px}.character-intro img{width:60px;height:60px}.compatibility-example{flex-direction:column;text-align:center}.score-display{justify-content:center}}:root{--font-primary: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-display: "Playfair Display", "Noto Serif JP", serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Code", monospace;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-black: 900;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--text-7xl: 4.5rem;--text-8xl: 6rem;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 1.75;--leading-extra: 2;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--jp-line-height-multiplier: 1.8;--jp-letter-spacing: .05em;--text-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--text-shadow-md: 0 2px 4px rgba(0, 0, 0, .1);--text-shadow-lg: 0 4px 8px rgba(0, 0, 0, .15);--text-shadow-xl: 0 8px 16px rgba(0, 0, 0, .2)}@media (max-width: 640px){:root{--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.1875rem;--text-2xl: 1.375rem;--text-3xl: 1.625rem;--text-4xl: 2rem;--text-5xl: 2.5rem;--text-6xl: 3rem}}body{font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-weight-regular);line-height:var(--leading-normal);letter-spacing:var(--tracking-normal);font-feature-settings:"kern" 1,"liga" 1,"calt" 1;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:lang(ja),.text-jp{line-height:var(--jp-line-height-multiplier);letter-spacing:var(--jp-letter-spacing);font-feature-settings:"jp90" 1,"jp04" 1;word-break:keep-all;overflow-wrap:break-word}h1,.h1{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:var(--font-weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin-bottom:1.5rem}h2,.h2{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin-bottom:1.25rem}h3,.h3{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-weight-semibold);line-height:var(--leading-snug);margin-bottom:1rem}h4,.h4{font-family:var(--font-primary);font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);line-height:var(--leading-snug);margin-bottom:.875rem}h5,.h5{font-family:var(--font-primary);font-size:var(--text-xl);font-weight:var(--font-weight-semibold);line-height:var(--leading-normal);margin-bottom:.75rem}h6,.h6{font-family:var(--font-primary);font-size:var(--text-lg);font-weight:var(--font-weight-semibold);line-height:var(--leading-normal);margin-bottom:.625rem}:lang(ja) h1,:lang(ja) .h1,:lang(ja) h2,:lang(ja) .h2,:lang(ja) h3,:lang(ja) .h3{font-family:var(--font-primary);font-weight:var(--font-weight-black);letter-spacing:var(--tracking-normal)}p,.text-body{font-size:var(--text-base);line-height:var(--leading-relaxed);margin-bottom:1rem}.text-body-lg{font-size:var(--text-lg);line-height:var(--leading-relaxed)}.text-body-sm{font-size:var(--text-sm);line-height:var(--leading-normal)}.text-lead{font-size:var(--text-xl);font-weight:var(--font-weight-light);line-height:var(--leading-relaxed);letter-spacing:var(--tracking-wide)}.text-game-title{font-family:var(--font-display);font-size:var(--text-7xl);font-weight:var(--font-weight-black);line-height:var(--leading-none);letter-spacing:var(--tracking-wider);text-transform:uppercase;text-shadow:var(--text-shadow-xl)}.text-character-name{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.text-dialogue{font-size:var(--text-lg);font-weight:var(--font-weight-regular);line-height:var(--leading-loose);letter-spacing:var(--tracking-normal)}.text-vn-speaker{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-weight-semibold);line-height:var(--leading-tight);margin-bottom:.5rem}.text-vn-message{font-size:var(--text-lg);line-height:var(--leading-extra);font-weight:var(--font-weight-regular)}.text-menu{font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:var(--leading-normal);letter-spacing:var(--tracking-wide)}.text-menu-lg{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.text-button{font-size:var(--text-base);font-weight:var(--font-weight-semibold);line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:none}.text-button-sm{font-size:var(--text-sm);font-weight:var(--font-weight-medium)}.text-button-lg{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.text-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:uppercase}.text-caption{font-size:var(--text-xs);font-weight:var(--font-weight-regular);line-height:var(--leading-normal);letter-spacing:var(--tracking-normal);opacity:.8}.text-stat{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-weight-bold);line-height:var(--leading-none);letter-spacing:var(--tracking-tight)}.text-stat-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:uppercase;opacity:.7}.text-achievement-title{font-size:var(--text-lg);font-weight:var(--font-weight-bold);line-height:var(--leading-tight)}.text-achievement-desc{font-size:var(--text-sm);font-weight:var(--font-weight-regular);line-height:var(--leading-normal);opacity:.9}.text-left{text-align:left}.text-right{text-align:right}.text-justify{text-align:justify}.font-light{font-weight:var(--font-weight-light)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-black{font-weight:var(--font-weight-black)}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.underline{text-decoration:underline}.no-underline{text-decoration:none}.line-through{text-decoration:line-through}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@media (prefers-color-scheme: dark){body{--text-shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--text-shadow-md: 0 2px 4px rgba(0, 0, 0, .3);--text-shadow-lg: 0 4px 8px rgba(0, 0, 0, .4);--text-shadow-xl: 0 8px 16px rgba(0, 0, 0, .5)}}@media (max-width: 768px){h1,.h1{font-size:var(--text-4xl)}h2,.h2{font-size:var(--text-3xl)}h3,.h3{font-size:var(--text-2xl)}h4,.h4{font-size:var(--text-xl)}h5,.h5{font-size:var(--text-lg)}h6,.h6{font-size:var(--text-base)}.text-game-title{font-size:var(--text-5xl)}.text-character-name{font-size:var(--text-xl)}.text-stat{font-size:var(--text-3xl)}}@media (max-width: 480px){h1,.h1{font-size:var(--text-3xl)}h2,.h2{font-size:var(--text-2xl)}.text-game-title{font-size:var(--text-4xl);letter-spacing:var(--tracking-wide)}}@media print{body{font-size:12pt;line-height:1.5}h1,h2,h3,h4,h5,h6{page-break-after:avoid;font-family:var(--font-primary)}p{orphans:3;widows:3}}:root{--primary-gradient: linear-gradient(135deg, #ff6b9d 0%, #c44569 50%, #f8b500 100%);--secondary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--accent-pink: #ff6b9d;--accent-gold: #f8b500;--accent-purple: #c44569;--text-primary: #2c3e50;--text-light: rgba(255, 255, 255, .95);--glass-bg: rgba(255, 255, 255, .1);--glass-border: rgba(255, 255, 255, .2);--shadow-soft: 0 10px 30px rgba(0, 0, 0, .1);--shadow-strong: 0 20px 60px rgba(0, 0, 0, .3);--border-radius: 20px;--transition: all .4s cubic-bezier(.4, 0, .2, 1)}.modern-mode{background:var(--primary-gradient);background-attachment:fixed;min-height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden;font-family:var(--font-primary)}.modern-content{width:100%;height:100%;display:flex;flex-direction:column;position:relative;z-index:1}.modern-mode:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 80%,rgba(255,107,157,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(248,181,0,.15) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(196,69,105,.1) 0%,transparent 50%);animation:backgroundFloat 20s ease-in-out infinite;pointer-events:none}.modern-mode:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="hearts" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><text x="10" y="15" text-anchor="middle" font-size="12" fill="rgba(255,255,255,0.03)">♡</text></pattern></defs><rect width="100" height="100" fill="url(%23hearts)"/></svg>');pointer-events:none;opacity:.5}@keyframes backgroundFloat{0%,to{transform:translate(0) translateY(0) rotate(0)}33%{transform:translate(-20px) translateY(-10px) rotate(1deg)}66%{transform:translate(10px) translateY(-20px) rotate(-1deg)}}.modern-header{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem 2rem;border-bottom:1px solid var(--glass-border);position:relative;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-weight-bold);color:var(--text-light);text-shadow:0 2px 10px rgba(0,0,0,.3)}.logo-icon{font-size:2.2rem;filter:drop-shadow(0 2px 10px rgba(255,107,157,.5));animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.header-status{display:flex;align-items:center;gap:1rem}.connection-status{display:flex;align-items:center;gap:.5rem;color:var(--text-light);font-size:var(--text-sm);font-weight:var(--font-weight-medium);background:#ffffff1a;padding:.5rem 1rem;border-radius:25px;border:1px solid rgba(255,255,255,.2)}.status-dot{width:10px;height:10px;border-radius:50%;background:#2ecc71;box-shadow:0 0 10px #2ecc7180;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.modern-screen{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem;position:relative;z-index:5}.hero-section{text-align:center;max-width:900px;margin:0 auto}.hero-title{font-family:var(--font-display);font-size:clamp(var(--text-4xl),5vw,var(--text-6xl));font-weight:var(--font-weight-bold);color:var(--text-light);margin-bottom:1.5rem;line-height:var(--leading-tight);text-shadow:0 4px 20px rgba(0,0,0,.3);animation:fadeInUp 1s ease-out}.highlight{background:linear-gradient(45deg,var(--accent-pink),var(--accent-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;display:inline-block}.highlight:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:3px;background:linear-gradient(45deg,var(--accent-pink),var(--accent-gold));border-radius:2px;opacity:.7}.hero-subtitle{font-size:var(--text-xl);color:#ffffffd9;margin-bottom:3rem;font-weight:var(--font-weight-regular);line-height:var(--leading-relaxed);animation:fadeInUp 1s ease-out .2s both}.hero-stats{display:flex;justify-content:center;gap:4rem;margin-bottom:4rem;animation:fadeInUp 1s ease-out .4s both}.stat-item{text-align:center;color:var(--text-light);position:relative}.stat-item:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:30px;height:2px;background:var(--accent-gold);border-radius:1px}.stat-number{display:block;font-family:var(--font-display);font-size:var(--text-5xl);font-weight:var(--font-weight-bold);color:var(--accent-gold);text-shadow:0 2px 10px rgba(248,181,0,.3);margin-bottom:.5rem}.stat-label{font-size:var(--text-base);opacity:.9;font-weight:var(--font-weight-medium)}.cta-button,.modern-cta{background:linear-gradient(45deg,var(--accent-pink),var(--accent-gold));color:#fff;border:none;padding:1.2rem 3rem;font-size:var(--text-xl);font-weight:var(--font-weight-semibold);border-radius:50px;cursor:pointer;transition:var(--transition);box-shadow:0 15px 35px #ff6b9d66;position:relative;overflow:hidden;animation:fadeInUp 1s ease-out .6s both;display:inline-flex;align-items:center;gap:.75rem;text-decoration:none}.cta-button: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 .5s}.cta-button:hover:before{left:100%}.cta-button:hover{transform:translateY(-3px);box-shadow:0 20px 50px #ff6b9d80}.cta-button:active{transform:translateY(-1px)}.character-selection{max-width:1200px;margin:0 auto;padding:3rem 2rem}.selection-header{text-align:center;margin-bottom:4rem;padding:2rem;background:#0000004d;border-radius:20px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.route-title,.selection-title{font-family:var(--font-display);font-size:clamp(var(--text-3xl),4vw,var(--text-5xl));font-weight:var(--font-weight-bold);color:var(--text-light);margin-bottom:1rem;text-shadow:0 4px 20px rgba(0,0,0,.5)}.route-subtitle,.selection-subtitle{font-size:var(--text-xl);color:#ffffffe6;font-weight:var(--font-weight-regular);text-shadow:0 2px 10px rgba(0,0,0,.4)}.character-grid,.character-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem;max-width:1200px;margin-left:auto;margin-right:auto}.character-card-modern{background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--border-radius);padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:var(--transition);border:2px solid rgba(255,255,255,.3);position:relative;overflow:hidden;transform:translateY(0);box-shadow:0 8px 32px #0000001a}.character-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(45deg,var(--accent-pink),var(--accent-gold));transform:scaleX(0);transition:transform .3s ease}.character-card-modern:hover:before{transform:scaleX(1)}.character-card-modern:hover{transform:translateY(-15px);background:#ffffffeb;box-shadow:var(--shadow-strong);border-color:#ffffff80}.char-avatar{font-size:5rem;margin-bottom:1.5rem;display:block;filter:drop-shadow(0 4px 15px rgba(0,0,0,.2));transition:transform .3s ease}.character-card-modern:hover .char-avatar{transform:scale(1.1)}.char-name{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:.5rem;text-shadow:none}.char-role{font-size:var(--text-lg);color:var(--accent-purple);margin-bottom:1.5rem;font-weight:var(--font-weight-semibold)}.char-description{font-size:var(--text-base);color:var(--text-primary);line-height:var(--leading-relaxed);font-weight:var(--font-weight-regular);opacity:.8}.character-card-modern[data-character=taro]{background:linear-gradient(135deg,#3498dbf2,#2980b9f2)}.character-card-modern[data-character=maya]{background:linear-gradient(135deg,#9b59b6f2,#8e44adf2)}.character-card-modern[data-character=kenji]{background:linear-gradient(135deg,#27ae60f2,#229954f2)}.character-card-modern[data-character=yuki]{background:linear-gradient(135deg,#e67e22f2,#d35400f2)}.character-card-modern[data-character=taro] .char-name,.character-card-modern[data-character=maya] .char-name,.character-card-modern[data-character=kenji] .char-name,.character-card-modern[data-character=yuki] .char-name{color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.8);font-weight:700}.character-card-modern[data-character=taro] .char-role,.character-card-modern[data-character=maya] .char-role,.character-card-modern[data-character=kenji] .char-role,.character-card-modern[data-character=yuki] .char-role{color:#fffffff2;text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}.character-card-modern[data-character=taro] .char-description,.character-card-modern[data-character=maya] .char-description,.character-card-modern[data-character=kenji] .char-description,.character-card-modern[data-character=yuki] .char-description{color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.3);line-height:1.6}.floating-elements{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1000}.mode-indicator{position:fixed;top:30px;left:30px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:.75rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;border:1px solid rgba(255,255,255,.1);pointer-events:auto;text-transform:uppercase;letter-spacing:.5px}.cost-monitor{position:fixed;top:30px;right:30px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:1rem 1.2rem;border-radius:15px;font-size:.9rem;z-index:1000;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:var(--transition);pointer-events:auto}.cost-monitor:hover{background:#000000e6;transform:translateY(-2px)}.cost-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;opacity:.8}.cost-toggle{background:none;border:none;color:#fff;cursor:pointer;font-size:.9rem;padding:0;margin-left:.5rem}.cost-value{font-weight:600;font-size:1.1rem;color:var(--accent-gold)}.floating-hearts{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.floating-heart{position:absolute;color:#ffffff1a;font-size:1.5rem;animation:floatUp 8s linear infinite}@keyframes floatUp{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100px) rotate(360deg);opacity:0}}@media (max-width: 768px){.modern-header{padding:1rem}.logo{font-size:1.5rem}.hero-stats{gap:2rem;flex-wrap:wrap}.character-grid{grid-template-columns:1fr;gap:1.5rem}.cost-monitor{top:20px;right:20px;padding:1rem}.modern-screen{padding:2rem 1rem}}@media (max-width: 480px){.hero-stats{gap:1.5rem}.stat-number{font-size:2.5rem}.cta-button{padding:1rem 2rem;font-size:1.1rem}.character-card-modern{padding:2rem 1.5rem}.selection-actions{flex-direction:column;gap:1rem}.selection-actions .game-menu-item{width:100%}}.selection-actions{display:flex;justify-content:space-between;align-items:center;margin-top:3rem;gap:2rem}.selection-actions .game-menu-item{flex:1;max-width:250px}.selection-actions .back-button{background:#ffffff1a;border-color:#fff3}.selection-actions .back-button:hover{background:#ffffff26}.selection-actions .proceed-button{background:linear-gradient(135deg,var(--accent-pink),var(--accent-gold));border:none;color:#fff;font-weight:600}.selection-actions .proceed-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-strong)}.selection-actions .proceed-button.disabled{background:#ffffff1a;color:#ffffff80;cursor:not-allowed;transform:none;box-shadow:none}.selection-actions .proceed-button.disabled:hover{background:#ffffff1a;transform:none}.route-selected{transform:translateY(-10px)!important;background:#fffffff2!important;box-shadow:var(--shadow-strong);border-color:var(--accent-gold)!important}.route-selected:before{transform:scaleX(1)!important}.character-card-modern .character-name{color:#2c3e50;font-weight:700}.character-card-modern .character-title{color:#34495e;font-weight:600;opacity:.9}.character-card-modern .character-details{color:#2c3e50;font-weight:500;justify-content:center}.character-card-modern .detail-item{color:#34495e}.character-card-modern .character-catchphrase{color:#c44569;font-weight:600}.character-card-modern .character-traits-modern{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;justify-content:center}.character-card-modern .character-traits-modern .trait{background:#c4456926;color:#c44569;padding:.3rem .8rem;border-radius:15px;font-size:.85rem;font-weight:600;border:1px solid rgba(196,69,105,.3)}.character-card-modern .affection-meter .meter-label{color:#2c3e50;font-weight:600}.character-card-modern .heart{color:#c445694d}.character-card-modern .heart.filled{color:#ff6b9d}.character-card-modern .character-portrait{position:relative;width:150px;height:150px;margin:0 auto 1.5rem}.character-card-modern .portrait-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff80,#ffffff1a);border-radius:50%;position:relative}.character-card-modern .portrait-frame{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:3px solid rgba(196,69,105,.3);border-radius:50%;pointer-events:none}.character-card-modern:hover .portrait-frame{border-color:var(--accent-gold)}.character-card-modern .character-info-modern{display:flex;flex-direction:column;align-items:center;gap:.5rem}.character-card-modern .card-glow{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(45deg,var(--accent-pink),var(--accent-gold));border-radius:var(--border-radius);opacity:0;transition:opacity .3s ease;z-index:-1;filter:blur(10px)}.character-card-modern:hover .card-glow{opacity:.3}:root{--btn-font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--btn-font-weight: 600;--btn-letter-spacing: .025em;--btn-transition: all .2s cubic-bezier(.4, 0, .2, 1);--btn-padding-xs: .375rem .75rem;--btn-padding-sm: .5rem 1rem;--btn-padding-md: .75rem 1.5rem;--btn-padding-lg: 1rem 2rem;--btn-padding-xl: 1.25rem 2.5rem;--btn-font-size-xs: .75rem;--btn-font-size-sm: .875rem;--btn-font-size-md: 1rem;--btn-font-size-lg: 1.125rem;--btn-font-size-xl: 1.25rem;--btn-radius-sm: 6px;--btn-radius-md: 8px;--btn-radius-lg: 12px;--btn-radius-xl: 16px;--btn-radius-pill: 9999px;--btn-primary-bg: #ff6b9d;--btn-primary-hover: #e74c7c;--btn-primary-active: #c44569;--btn-primary-text: #ffffff;--btn-secondary-bg: rgba(255, 255, 255, .1);--btn-secondary-hover: rgba(255, 255, 255, .2);--btn-secondary-active: rgba(255, 255, 255, .15);--btn-secondary-border: rgba(255, 255, 255, .3);--btn-secondary-text: #ffffff;--btn-ghost-bg: transparent;--btn-ghost-hover: rgba(255, 255, 255, .1);--btn-ghost-active: rgba(255, 255, 255, .05);--btn-ghost-text: currentColor;--btn-danger-bg: #ef4444;--btn-danger-hover: #dc2626;--btn-danger-active: #b91c1c;--btn-danger-text: #ffffff;--btn-success-bg: #10b981;--btn-success-hover: #059669;--btn-success-active: #047857;--btn-success-text: #ffffff;--btn-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--btn-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--btn-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--btn-focus-ring: 0 0 0 3px rgba(255, 107, 157, .3);--btn-focus-ring-danger: 0 0 0 3px rgba(239, 68, 68, .3);--btn-focus-ring-success: 0 0 0 3px rgba(16, 185, 129, .3)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;margin:0;padding:0;font-family:var(--btn-font-family);font-weight:var(--btn-font-weight);letter-spacing:var(--btn-letter-spacing);text-align:center;text-decoration:none;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;position:relative;overflow:hidden;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:var(--btn-transition);padding:var(--btn-padding-md);font-size:var(--btn-font-size-md);border-radius:var(--btn-radius-md)}.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:none;box-shadow:var(--btn-focus-ring)}.btn.loading{color:transparent;pointer-events:none}.btn.loading:after{content:"";position:absolute;width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-shadow-md)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover);transform:translateY(-1px);box-shadow:var(--btn-shadow-lg)}.btn-primary:active:not(:disabled){background:var(--btn-primary-active);transform:translateY(0);box-shadow:var(--btn-shadow-sm)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:1px solid var(--btn-secondary-border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.btn-secondary:hover:not(:disabled){background:var(--btn-secondary-hover);border-color:#ffffff80;transform:translateY(-1px)}.btn-secondary:active:not(:disabled){background:var(--btn-secondary-active);transform:translateY(0)}.btn-ghost{background:var(--btn-ghost-bg);color:var(--btn-ghost-text);border:1px solid currentColor}.btn-ghost:hover:not(:disabled){background:var(--btn-ghost-hover);transform:translateY(-1px)}.btn-ghost:active:not(:disabled){background:var(--btn-ghost-active);transform:translateY(0)}.btn-danger{background:var(--btn-danger-bg);color:var(--btn-danger-text);box-shadow:var(--btn-shadow-md)}.btn-danger:hover:not(:disabled){background:var(--btn-danger-hover);transform:translateY(-1px);box-shadow:var(--btn-shadow-lg)}.btn-danger:active:not(:disabled){background:var(--btn-danger-active);transform:translateY(0);box-shadow:var(--btn-shadow-sm)}.btn-danger:focus-visible{box-shadow:var(--btn-focus-ring-danger)}.btn-success{background:var(--btn-success-bg);color:var(--btn-success-text);box-shadow:var(--btn-shadow-md)}.btn-success:hover:not(:disabled){background:var(--btn-success-hover);transform:translateY(-1px);box-shadow:var(--btn-shadow-lg)}.btn-success:active:not(:disabled){background:var(--btn-success-active);transform:translateY(0);box-shadow:var(--btn-shadow-sm)}.btn-success:focus-visible{box-shadow:var(--btn-focus-ring-success)}.btn-xs{padding:var(--btn-padding-xs);font-size:var(--btn-font-size-xs);border-radius:var(--btn-radius-sm)}.btn-sm{padding:var(--btn-padding-sm);font-size:var(--btn-font-size-sm);border-radius:var(--btn-radius-sm)}.btn-lg{padding:var(--btn-padding-lg);font-size:var(--btn-font-size-lg);border-radius:var(--btn-radius-lg)}.btn-xl{padding:var(--btn-padding-xl);font-size:var(--btn-font-size-xl);border-radius:var(--btn-radius-xl)}.btn-pill{border-radius:var(--btn-radius-pill)}.btn-square{border-radius:0}.btn-circle{aspect-ratio:1;border-radius:50%;padding:0;width:3rem;height:3rem}.btn-circle.btn-sm{width:2rem;height:2rem}.btn-circle.btn-lg{width:4rem;height:4rem}.btn-group{display:inline-flex;gap:0}.btn-group>.btn{border-radius:0}.btn-group>.btn:first-child{border-top-left-radius:var(--btn-radius-md);border-bottom-left-radius:var(--btn-radius-md)}.btn-group>.btn:last-child{border-top-right-radius:var(--btn-radius-md);border-bottom-right-radius:var(--btn-radius-md)}.btn-group>.btn:not(:last-child){border-right:1px solid rgba(0,0,0,.1)}.btn-icon{padding:.75rem}.btn-icon.btn-sm{padding:.5rem}.btn-icon.btn-lg{padding:1rem}.btn>.icon{font-size:1.2em;line-height:1}.btn>.icon-left{margin-right:.25rem}.btn>.icon-right{margin-left:.25rem}.btn.active,.btn[aria-pressed=true]{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:inset 0 2px 4px #0000001a}.btn-pulse{animation:btn-pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes btn-pulse{0%,to{opacity:1}50%{opacity:.8}}.btn-ripple{position:relative;overflow:hidden}.btn-ripple:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-ripple:active:before{width:300px;height:300px}.btn-vn{background:#000c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);color:#fff;transition:var(--btn-transition)}.btn-vn:hover:not(:disabled){background:#ff6b9de6;border-color:var(--btn-primary-bg);transform:translate(5px)}.btn-control{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;font-size:.875rem;border-radius:var(--btn-radius-pill)}.btn-control:hover:not(:disabled){background:#fff3;border-color:#fff6}.btn-control.active{background:linear-gradient(135deg,var(--btn-primary-bg),#f8b500);border-color:transparent}.btn-menu-item{width:100%;justify-content:flex-start;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:1rem 1.5rem;font-size:1rem;border-radius:var(--btn-radius-lg);text-align:left}.btn-menu-item:hover:not(:disabled){background:#ffffff1a;border-color:var(--btn-primary-bg);transform:translate(5px)}.btn-explore{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-radius:var(--btn-radius-pill);padding:.75rem 1.5rem;font-weight:600}.btn-explore:hover:not(:disabled){background:var(--btn-primary-hover);transform:translate(5px);box-shadow:0 5px 20px #ff6b9d66}@media (max-width: 768px){.btn{min-height:44px;min-width:44px}.btn-group{flex-direction:column;width:100%}.btn-group>.btn{width:100%;border-radius:0;border-right:none;border-bottom:1px solid rgba(0,0,0,.1)}.btn-group>.btn:first-child{border-radius:var(--btn-radius-md) var(--btn-radius-md) 0 0}.btn-group>.btn:last-child{border-radius:0 0 var(--btn-radius-md) var(--btn-radius-md);border-bottom:none}}@media (hover: none){.btn:hover{transform:none!important;box-shadow:none!important}.btn:active{opacity:.9;transform:scale(.98)!important}}@media (prefers-color-scheme: dark){:root{--btn-secondary-bg: rgba(255, 255, 255, .05);--btn-secondary-hover: rgba(255, 255, 255, .1);--btn-secondary-border: rgba(255, 255, 255, .2)}}.btn-block{width:100%}.btn-rounded{border-radius:var(--btn-radius-lg)}.btn-shadow{box-shadow:var(--btn-shadow-lg)}.btn-no-shadow{box-shadow:none!important}.btn-fade-in{animation:btn-fade-in .3s ease-out}@keyframes btn-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}:root{--vn-bg-gradient: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);--vn-text-primary: #ffffff;--vn-text-secondary: #b8c5d6;--vn-accent-pink: #ff6b9d;--vn-accent-gold: #f8b500;--vn-glass-bg: rgba(255, 255, 255, .1);--vn-glass-border: rgba(255, 255, 255, .2);--vn-shadow: 0 10px 30px rgba(0, 0, 0, .3);--vn-transition: all .4s cubic-bezier(.4, 0, .2, 1);--vn-input-bg: rgba(0, 0, 0, .3);--vn-input-border: rgba(255, 255, 255, .3)}.visual-novel-mode{background:var(--vn-bg-gradient);min-height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden;font-family:Noto Sans JP,sans-serif}.visual-novel-mode:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 70%,rgba(255,107,157,.1) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(248,181,0,.08) 0%,transparent 50%);animation:vnBackgroundFloat 15s ease-in-out infinite;pointer-events:none}@keyframes vnBackgroundFloat{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.vn-header{background:var(--vn-glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1rem 2rem;border-bottom:1px solid var(--vn-glass-border);position:relative;z-index:100}.vn-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.vn-character-info{display:flex;align-items:center;gap:1rem}.vn-char-avatar{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,var(--vn-accent-pink),var(--vn-accent-gold));color:#fff;font-weight:600;box-shadow:0 4px 15px #ff6b9d4d}.vn-char-details h3{color:var(--vn-text-primary);font-size:var(--text-xl);font-weight:var(--font-weight-semibold);margin-bottom:.25rem}.vn-char-status{color:var(--vn-text-secondary);font-size:var(--text-sm);font-weight:var(--font-weight-regular)}.vn-stats{display:flex;align-items:center;gap:2rem}.intimacy-display{display:flex;align-items:center;gap:.75rem;background:var(--vn-glass-bg);padding:.5rem 1rem;border-radius:25px;border:1px solid var(--vn-glass-border)}.intimacy-label{color:var(--vn-text-secondary);font-size:var(--text-sm);font-weight:var(--font-weight-medium)}.intimacy-bar{width:100px;height:6px;background:#fff3;border-radius:3px;overflow:hidden}.intimacy-fill{height:100%;background:linear-gradient(90deg,var(--vn-accent-pink),var(--vn-accent-gold));border-radius:3px;transition:width .5s ease;width:15%}.intimacy-value{color:var(--vn-accent-gold);font-size:var(--text-sm);font-weight:var(--font-weight-semibold)}.vn-main{flex:1;display:flex;position:relative}.character-display{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.1) 100%)}.character-scene{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.character-image{width:400px;height:600px;display:flex;align-items:center;justify-content:center;font-size:12rem;color:var(--vn-text-primary);filter:drop-shadow(0 10px 30px rgba(0,0,0,.3));transition:var(--vn-transition);position:relative}.character-image:before{content:"";position:absolute;top:-20px;left:-20px;right:-20px;bottom:-20px;background:radial-gradient(ellipse at center,rgba(255,107,157,.1) 0%,transparent 70%);border-radius:50%;animation:characterGlow 3s ease-in-out infinite}@keyframes characterGlow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.character-image.elite{color:#4169e1}.character-image.artist{color:#ec4899}.character-image.engineer{color:#06b6d4}.character-image.balanced{color:#10b981}.character-emotion{position:absolute;top:-50px;left:50%;transform:translate(-50%);background:var(--vn-glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--vn-text-primary);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;border:1px solid var(--vn-glass-border);animation:emotionFloat 2s ease-in-out infinite}@keyframes emotionFloat{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-5px)}}.dialogue-box{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(135deg,#000000e6,#1a1a2ef2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:2px solid var(--vn-glass-border);padding:2rem;min-height:200px;display:flex;flex-direction:column;justify-content:center}.speaker-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.speaker-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:linear-gradient(135deg,var(--vn-accent-pink),var(--vn-accent-gold));color:#fff;font-weight:600}.speaker-name{color:var(--vn-text-primary);font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);font-family:var(--font-display)}.message-text{color:var(--vn-text-primary);font-size:var(--text-lg);line-height:var(--leading-loose);margin-bottom:1.5rem;min-height:60px;font-weight:var(--font-weight-regular);position:relative}.typing-cursor{display:inline-block;width:2px;height:1.2em;background-color:var(--vn-text-primary);margin-left:2px;animation:cursorBlink 1s step-end infinite;vertical-align:text-bottom}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.continue-indicator{position:absolute;bottom:1rem;right:2rem;color:var(--vn-accent-gold);font-size:1.5rem;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.choices-container{position:absolute;bottom:220px;left:2rem;right:2rem;z-index:10}.choices-list{display:flex;flex-direction:column;gap:1rem;max-width:600px;margin:0 auto}.choice-btn{background:#000c;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);color:#fff;padding:1rem 1.5rem;border-radius:15px;cursor:pointer;transition:var(--vn-transition);font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:var(--leading-normal);text-align:left;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000004d}.choice-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,107,157,.1),transparent);transition:left .5s}.choice-btn:hover:before{left:100%}.choice-btn:hover{background:#ff6b9de6;border-color:var(--vn-accent-pink);transform:translate(10px);box-shadow:0 6px 12px #ff6b9d66}.choice-btn:active{transform:translate(5px)}.choice-btn:disabled{opacity:.5;cursor:not-allowed;background:#47556999}.choice-btn.chapter-navigation{background:linear-gradient(135deg,#dc2626,#991b1b);border:2px solid rgba(239,68,68,.5);font-weight:600;position:relative;overflow:hidden}.choice-btn.chapter-navigation: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 .5s}.choice-btn.chapter-navigation:hover:before{left:100%}.choice-btn.chapter-navigation:hover{background:linear-gradient(135deg,#ef4444,#dc2626);transform:translateY(-2px) translate(10px);box-shadow:0 8px 16px #dc26264d}.choice-btn.chapter-navigation .choice-icon{display:inline-block;margin-right:.5rem;animation:pulse-icon 2s infinite}.choice-btn.story-navigation{background:linear-gradient(135deg,#2563eb,#1e40af);border:2px solid rgba(59,130,246,.5)}.choice-btn.story-navigation:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);transform:translateY(-2px) translate(10px);box-shadow:0 8px 16px #2563eb4d}@keyframes pulse-icon{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.vn-side-menu{position:fixed;top:0;right:-300px;width:300px;height:100vh;background:linear-gradient(135deg,#000000f2,#1a1a2ef2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--vn-glass-border);padding:2rem;transition:right .4s ease;z-index:200}.menu-header{color:var(--vn-text-primary);font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);margin-bottom:2rem;text-align:center;font-family:var(--font-display)}.menu-section{margin-bottom:2rem}.menu-section h4{color:var(--vn-accent-gold);font-size:var(--text-base);font-weight:var(--font-weight-semibold);margin-bottom:1rem;text-transform:uppercase;letter-spacing:var(--tracking-wider)}.menu-btn{width:100%;background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);color:var(--vn-text-primary);padding:.75rem 1rem;border-radius:10px;cursor:pointer;transition:var(--vn-transition);font-size:var(--text-sm);font-weight:var(--font-weight-medium);margin-bottom:.5rem}.menu-btn:hover{background:#ffffff26;border-color:var(--vn-accent-pink)}.menu-btn.active{background:linear-gradient(135deg,var(--vn-accent-pink),var(--vn-accent-gold));border-color:transparent}.menu-toggle{position:fixed;top:50%;right:20px;transform:translateY(-50%);width:50px;height:50px;background:var(--vn-glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--vn-glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--vn-transition);z-index:150}.menu-toggle:hover{background:#ffffff26;transform:translateY(-50%) scale(1.1)}.menu-toggle span{color:var(--vn-text-primary);font-size:1.2rem}.vn-nav-controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:1rem;z-index:100}.nav-btn{width:50px;height:50px;background:var(--vn-glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--vn-glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--vn-transition);color:var(--vn-text-primary);font-size:1.2rem}.nav-btn:hover{background:#ffffff26;transform:translateY(-3px)}.nav-btn:active{transform:translateY(-1px)}.vn-background{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--vn-bg-gradient);z-index:1}.bg-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.3) 100%)}.bg-particles{position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="stars" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23stars)"/></svg>');opacity:.3}.vn-character-display{position:absolute;top:0;left:0;right:0;bottom:200px;display:flex;align-items:center;justify-content:center;z-index:10}.character-portrait{position:relative;display:flex;flex-direction:column;align-items:center}.vn-ui-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:50}.vn-top-bar{position:absolute;top:0;left:0;right:0;background:var(--vn-glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--vn-glass-border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;pointer-events:auto}.vn-menu-btn{width:40px;height:40px;background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--vn-transition);color:var(--vn-text-primary)}.vn-menu-btn:hover{background:#ffffff26;transform:scale(1.05)}.menu-icon{font-size:1.2rem}.chapter-info{color:var(--vn-text-primary);font-weight:var(--font-weight-semibold);font-size:var(--text-lg);font-family:var(--font-display)}.vn-status{display:flex;align-items:center;gap:1rem}.vn-side-menu{position:fixed;top:0;right:-350px;width:350px;height:100vh;background:linear-gradient(135deg,#000000f2,#1a1a2ef2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--vn-glass-border);padding:2rem;transition:right .4s ease;z-index:200;pointer-events:auto;overflow-y:auto}.vn-side-menu.active{right:0}.vn-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--vn-glass-border)}.vn-menu-header h3{color:var(--vn-text-primary);font-size:1.5rem;font-weight:600;font-family:Playfair Display,serif;margin:0}.close-vn-menu{width:35px;height:35px;background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--vn-transition);color:var(--vn-text-primary);font-size:1.2rem}.close-vn-menu:hover{background:#ef4444;border-color:#ef4444;color:#fff}.vn-menu-content{display:flex;flex-direction:column;gap:.75rem}.vn-menu-item{width:100%;background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);color:var(--vn-text-primary);padding:1rem 1.5rem;border-radius:12px;cursor:pointer;transition:var(--vn-transition);font-size:1rem;font-weight:500;display:flex;align-items:center;gap:1rem;text-align:left}.vn-menu-item:hover{background:#ffffff26;border-color:var(--vn-accent-pink);transform:translate(5px)}.vn-menu-item:active{transform:translate(2px)}.vn-menu-item .menu-icon{font-size:1.3rem;width:24px;text-align:center}.vn-message-box{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(135deg,#000000e6,#1a1a2ef2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:2px solid var(--vn-glass-border);padding:2rem;min-height:200px;z-index:20;transition:background .2s ease}.vn-message-box:hover{background:linear-gradient(135deg,#000000eb,#1a1a2ef7)}.message-content{display:flex;flex-direction:column;justify-content:center;height:100%}.speaker-name{color:var(--vn-text-primary);font-size:1.3rem;font-weight:600;font-family:Playfair Display,serif;margin-bottom:1rem}.message-controls{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.next-btn{background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);color:var(--vn-accent-gold);width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--vn-transition);font-size:1.2rem}.next-btn:hover{background:#ffffff26;transform:scale(1.1)}.auto-mode{display:flex;align-items:center}.skip-btn,.auto-btn,.log-btn,.speech-bubble-btn{background:var(--vn-glass-bg);border:1px solid var(--vn-glass-border);color:var(--vn-text-primary);padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:var(--vn-transition);font-size:.9rem;font-weight:500;position:relative}.skip-btn:hover,.auto-btn:hover,.log-btn:hover,.speech-bubble-btn:hover{background:#ffffff26;border-color:var(--vn-accent-gold)}.skip-btn.active{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:transparent;color:#fff}.auto-btn.active{background:linear-gradient(135deg,var(--vn-accent-pink),var(--vn-accent-gold));border-color:transparent;color:#fff}.speech-bubble-btn.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-color:transparent;color:#fff}.auto-indicator{display:inline-block;width:8px;height:8px;background:#fff;border-radius:50%;margin-left:6px;animation:autoModePulse 2s ease-in-out infinite}@keyframes autoModePulse{0%,to{opacity:.6;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.log-btn,.speech-bubble-btn{padding:.5rem .75rem;font-size:1.1rem}.vn-choices-container{position:absolute;bottom:220px;left:2rem;right:2rem;z-index:25}.vn-choices-list{display:flex;flex-direction:column;gap:1rem;max-width:600px;margin:0 auto}@media (max-width: 768px){.vn-header{padding:1rem}.vn-stats{gap:1rem}.intimacy-bar{width:80px}.character-image{width:300px;height:450px;font-size:8rem}.dialogue-box{padding:1.5rem;min-height:180px}.message-text{font-size:1rem}.choices-container{left:1rem;right:1rem;bottom:200px}.vn-side-menu{width:280px;padding:1.5rem}}@media (max-width: 480px){.vn-header-content{flex-direction:column;gap:1rem;align-items:flex-start}.character-image{width:250px;height:350px;font-size:6rem}.dialogue-box{padding:1rem;min-height:160px}.speaker-info{margin-bottom:.75rem}.message-text{font-size:.95rem;line-height:1.6}.vn-side-menu{width:100%;right:-100%}}.chapter-end-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .5s ease-out}.chapter-end-content{text-align:center;color:#fff;max-width:600px;padding:3rem}.chapter-end-title{font-size:3rem;font-weight:100;letter-spacing:.5rem;margin-bottom:2rem;text-shadow:0 0 20px rgba(255,255,255,.5)}.chapter-end-recap{margin-bottom:3rem;padding:2rem;background:#ffffff0d;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.chapter-end-recap h3{font-size:1.2rem;font-weight:300;margin-bottom:1rem;opacity:.8}.recap-message{margin:.5rem 0;font-size:.9rem;opacity:.7;font-style:italic;line-height:1.6}.chapter-end-options{display:flex;flex-direction:column;gap:1rem}.chapter-option-btn{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 2rem;font-size:1.2rem;background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;cursor:pointer;transition:all .3s ease;letter-spacing:.1em}.chapter-option-btn:hover{background:#fff3;border-color:#fff9;transform:translateY(-2px);box-shadow:0 5px 20px #fff3}.chapter-option-btn.continue{background:#8a2be24d;border-color:#8a2be299}.chapter-option-btn.continue:hover{background:#8a2be280;border-color:#8a2be2}.chapter-option-btn.restart{background:#ff8c004d;border-color:#ff8c0099}.chapter-option-btn.restart:hover{background:#ff8c0080;border-color:#ff8c00}.chapter-option-btn.menu{background:#4682b44d;border-color:#4682b499}.chapter-option-btn.menu:hover{background:#4682b480;border-color:#4682b4}.option-icon{font-size:1.5rem}.vn-interaction-container{position:absolute;bottom:220px;left:2rem;right:2rem;z-index:25;display:flex;flex-direction:column;gap:1rem}.show-input-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;margin-top:1rem;background:var(--vn-input-bg);color:var(--vn-text-secondary);border:1px solid var(--vn-input-border);border-radius:8px;cursor:pointer;transition:var(--vn-transition);font-size:.9rem}.show-input-btn:hover{background:#ffffff26;color:var(--vn-text-primary);border-color:var(--vn-accent-pink)}.input-icon{font-size:1.1rem}.vn-input-container{background:var(--vn-glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--vn-glass-border);border-radius:12px;padding:1.5rem;animation:slideIn .3s ease-out}.input-type-indicator{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.4rem .8rem;margin-bottom:.8rem;font-size:.8rem;text-align:center}.ime-active{color:#fbbf24;font-weight:600}.japanese-input{color:#f472b6;font-weight:500}.english-input{color:#60a5fa;font-weight:500}.double-enter-hint{background:linear-gradient(135deg,#ff6b9d1a,#ffb86c1a);border:1px solid var(--vn-accent-pink);border-radius:8px;padding:.5rem 1rem;margin-bottom:1rem;font-size:.9rem;color:var(--vn-accent-pink);text-align:center;animation:pulseHint 1s ease-in-out infinite}@keyframes pulseHint{0%,to{opacity:.8}50%{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.input-wrapper{display:flex;gap:1rem;align-items:flex-end}.user-input{flex:1;background:var(--vn-input-bg);color:var(--vn-text-primary);border:1px solid var(--vn-input-border);border-radius:8px;padding:.75rem 1rem;font-size:1rem;font-family:inherit;resize:none;transition:var(--vn-transition)}.user-input:focus{outline:none;border-color:var(--vn-accent-pink);background:#00000080}.user-input::-moz-placeholder{color:var(--vn-text-secondary);opacity:.7}.user-input::placeholder{color:var(--vn-text-secondary);opacity:.7}.send-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--vn-accent-pink),var(--vn-accent-gold));color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:var(--vn-transition);white-space:nowrap}.send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #ff6b9d66}.send-btn:disabled{opacity:.5;cursor:not-allowed}.alternative-choices{display:flex;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--vn-glass-border)}.or-text{color:var(--vn-text-secondary);font-size:.9rem}.show-choices-btn{padding:.5rem 1rem;background:transparent;color:var(--vn-accent-gold);border:1px solid var(--vn-accent-gold);border-radius:6px;cursor:pointer;font-size:.9rem;transition:var(--vn-transition)}.show-choices-btn:hover{background:#f8b5001a}.generating-indicator{display:flex;justify-content:center;padding:2rem}.loading-dots{color:var(--vn-text-secondary);font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.loading-dots .dots{display:inline-block;animation:loadingDots 1.4s infinite ease-in-out both}@keyframes loadingDots{0%,80%,to{opacity:.3}40%{opacity:1}}.debug-mode-indicator{position:fixed;bottom:13rem;right:1rem;display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem;background:#000000e6;border:2px solid;border-radius:8px;font-family:monospace;font-size:.75rem;font-weight:600;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease;animation:fadeInSlide .5s ease-out}.debug-mode-indicator.static-mode{border-color:#3498db;box-shadow:0 0 15px #3498db4d}.debug-mode-indicator.dynamic-mode{border-color:#e74c3c;box-shadow:0 0 15px #e74c3c4d}.mode-label{color:var(--vn-accent-gold);font-weight:700;letter-spacing:.5px}.source-label{color:#ffffffe6;font-size:.7rem;font-weight:500}.mode-status{color:#ffffffb3;font-size:.65rem;font-weight:400;font-style:italic}.pagination-status{color:#fffc;font-size:.65rem;font-weight:600;margin-left:.5rem;background:#ff950033;padding:2px 8px;border-radius:10px;border:1px solid rgba(255,149,0,.3)}.debug-mode-indicator.static-mode .mode-label{color:#3498db}.debug-mode-indicator.static-mode .source-label{color:#3498dbcc}.debug-mode-indicator.dynamic-mode .mode-label{color:#e74c3c}.debug-mode-indicator.dynamic-mode .source-label{color:#e74c3ccc}@keyframes fadeInSlide{0%{opacity:0;transform:translate(20px) translateY(10px)}to{opacity:1;transform:translate(0) translateY(0)}}.debug-mode-indicator.dynamic-mode{animation:fadeInSlide .5s ease-out,pulse 2s infinite}.debug-mode-indicator.generating{animation:fadeInSlide .5s ease-out,generatePulse 1s infinite}@keyframes pulse{0%,to{box-shadow:0 0 15px #e74c3c4d}50%{box-shadow:0 0 25px #e74c3c80}}@keyframes generatePulse{0%,to{box-shadow:0 0 20px #ffa50066;border-color:#ff9500}50%{box-shadow:0 0 35px #ffa500b3;border-color:#ffb347}}.debug-mode-indicator.generating .mode-label{color:#ff9500}.debug-mode-indicator.generating .source-label{color:#ff9500cc}@media (max-width: 768px){.vn-interaction-container{bottom:200px;left:1rem;right:1rem}.vn-input-container{padding:1rem}.input-wrapper{flex-direction:column}.send-btn{width:100%}.debug-mode-indicator{font-size:.7rem;padding:.5rem .75rem}}.pagination-indicator{position:absolute;bottom:10px;right:20px;display:flex;align-items:center;background:#0000004d;padding:4px 10px;border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:fadeIn .3s ease;pointer-events:none}.page-info{color:#ffffffb3;font-size:12px;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.pause-indicator{display:inline-block;color:var(--vn-text-primary);opacity:.7;font-size:1.2em;letter-spacing:.3em;animation:pausePulse 1.5s ease-in-out infinite;margin-left:4px}@keyframes pausePulse{0%,to{opacity:.4}50%{opacity:.8}}.vn-choices-container.millionaire-style{position:fixed;bottom:200px;left:50%;transform:translate(-50%);width:90%;max-width:800px;z-index:100;animation:slideUpFade .4s ease-out}.choices-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%}.millionaire-option{background:linear-gradient(135deg,#000000e6,#141414e6);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid transparent;border-radius:25px;padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;transition:all .3s ease;position:relative;overflow:hidden;min-height:60px;box-shadow:0 4px 12px #0000004d}.option-letter{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,#f8b500,#f39c12);color:#000;font-weight:800;font-size:1.2rem;border-radius:50%;flex-shrink:0;box-shadow:0 2px 6px #f8b50066}.option-text{flex:1;text-align:left;font-size:1rem;line-height:1.4}.millionaire-option:hover:not(:disabled){background:linear-gradient(135deg,#f8b500,#f39c12);border-color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #f8b50080}.millionaire-option:hover:not(:disabled) .option-letter{background:linear-gradient(135deg,#000,#222);color:#f8b500}.millionaire-option:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #f8b5004d}.millionaire-option.chapter-navigation{background:linear-gradient(135deg,#dc2626e6,#991b1be6)}.millionaire-option.chapter-navigation:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 6px 20px #dc262680}.millionaire-option.story-navigation{background:linear-gradient(135deg,#3b82f6e6,#2563ebe6)}.millionaire-option.story-navigation:hover:not(:disabled){background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 6px 20px #3b82f680}.millionaire-option:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#47556999,#33415599)}.millionaire-option:disabled .option-letter{background:linear-gradient(135deg,#64748b,#475569);box-shadow:none}.choices-grid:has(.millionaire-option:nth-child(1):last-child){grid-template-columns:1fr;max-width:400px;margin:0 auto}.choices-grid:has(.millionaire-option:nth-child(2):last-child){grid-template-columns:repeat(2,1fr)}.choices-grid:has(.millionaire-option:nth-child(3):last-child){grid-template-columns:repeat(3,1fr);gap:.75rem}.choices-grid:has(.millionaire-option:nth-child(3):last-child) .millionaire-option{padding:.875rem 1.25rem}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.vn-choices-container.millionaire-style{width:95%;bottom:180px}.choices-grid{gap:.75rem}.millionaire-option{padding:.875rem 1.25rem;min-height:56px}.option-letter{width:28px;height:28px;font-size:1rem}.option-text{font-size:.95rem}@media (max-width: 480px){.choices-grid{grid-template-columns:1fr;max-width:100%}.vn-choices-container.millionaire-style{bottom:160px}}}:root{--re-bg-gradient: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #cbd5e1 100%);--re-primary: #1e293b;--re-secondary: #475569;--re-accent-blue: #3b82f6;--re-accent-green: #10b981;--re-accent-gold: #f59e0b;--re-text-primary: #1e293b;--re-text-secondary: #64748b;--re-text-muted: #94a3b8;--re-bg-white: #ffffff;--re-bg-light: #f8fafc;--re-border: #e2e8f0;--re-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1);--re-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--re-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--re-transition: all .3s cubic-bezier(.4, 0, .2, 1)}.real-estate-mode{background:var(--re-bg-gradient);min-height:100vh;font-family:Noto Sans JP,sans-serif;color:var(--re-text-primary)}.re-header{background:var(--re-bg-white);border-bottom:1px solid var(--re-border);padding:1.5rem 2rem;box-shadow:var(--re-shadow);position:sticky;top:0;z-index:100}.re-header-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.re-logo-section{display:flex;flex-direction:column;align-items:flex-start}.re-logo{font-size:1.8rem;font-weight:700;color:var(--re-text-primary);margin:0;font-family:Playfair Display,serif}.re-logo-tagline{color:var(--re-text-secondary);font-size:.9rem;margin-top:.25rem}.re-main-nav{display:flex;gap:2rem;align-items:center}.re-nav-link{color:var(--re-text-secondary);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:var(--re-transition)}.re-nav-link:hover{color:var(--re-accent-blue);background:var(--re-bg-light)}.re-nav-link.active{color:var(--re-accent-blue);background:#3b82f61a}.re-header-actions{display:flex;align-items:center;gap:1rem}.current-character-info{display:flex;align-items:center;gap:.75rem;background:var(--re-bg-light);padding:.75rem 1rem;border-radius:25px;border:1px solid var(--re-border)}.char-avatar-small{width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#f8b500)}.re-back-btn{width:40px;height:40px;border-radius:50%;background:var(--re-bg-light);border:1px solid var(--re-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--re-transition);color:var(--re-text-secondary)}.re-back-btn:hover{background:var(--re-accent-blue);color:#fff;transform:translate(-2px)}.re-title-info h1{font-size:1.8rem;font-weight:700;color:var(--re-text-primary);margin-bottom:.25rem;font-family:Playfair Display,serif}.re-subtitle{color:var(--re-text-secondary);font-size:.95rem;display:flex;align-items:center;gap:.5rem}.re-current-character{display:flex;align-items:center;gap:.75rem;background:var(--re-bg-light);padding:.75rem 1rem;border-radius:25px;border:1px solid var(--re-border)}.re-char-avatar-small{width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#f8b500)}.re-char-name{color:var(--re-text-primary);font-weight:600;font-size:.95rem}.re-main-content{max-width:1400px;margin:0 auto;padding:2rem}.re-search-filters{background:var(--re-bg-white);border-radius:15px;padding:2rem;margin-bottom:2rem;box-shadow:var(--re-shadow);border:1px solid var(--re-border)}.filter-container{display:flex;gap:2rem;align-items:end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.filter-label{font-size:.9rem;font-weight:600;color:var(--re-text-primary)}.filter-select{padding:.75rem 1rem;border:1px solid var(--re-border);border-radius:8px;background:var(--re-bg-white);color:var(--re-text-primary);font-size:.9rem;transition:var(--re-transition)}.filter-select:focus{outline:none;border-color:var(--re-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.re-search-btn{background:var(--re-accent-blue);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:var(--re-transition);height:-moz-fit-content;height:fit-content}.re-search-btn:hover{background:#2563eb;transform:translateY(-1px)}.re-properties-section{background:var(--re-bg-white);border-radius:15px;padding:2rem;box-shadow:var(--re-shadow);border:1px solid var(--re-border)}.re-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--re-border)}.re-section-header h2{font-size:1.8rem;font-weight:700;color:var(--re-text-primary);font-family:Playfair Display,serif;margin:0}.character-recommendation{display:flex;align-items:center;gap:.5rem;background:var(--re-bg-light);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;color:var(--re-text-secondary)}.character-recommendation span{color:var(--re-accent-blue);font-weight:600}.re-properties-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.re-property-card{background:var(--re-bg-white);border:1px solid var(--re-border);border-radius:15px;overflow:hidden;cursor:pointer;transition:var(--re-transition);position:relative;box-shadow:var(--re-shadow)}.re-property-card:hover{transform:translateY(-5px);box-shadow:var(--re-shadow-xl);border-color:var(--re-accent-blue)}.re-property-image{height:200px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--re-text-muted);position:relative}.re-property-image:after{content:"🏢";font-size:4rem;opacity:.3}.property-badge{position:absolute;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600;color:#fff}.property-badge.new{top:1rem;left:1rem;background:var(--re-accent-green)}.property-badge.featured{top:1rem;left:1rem;background:var(--re-accent-gold)}.property-badge.yield{top:1rem;right:1rem;background:var(--re-accent-blue)}.character-stamp{position:absolute;bottom:1rem;right:1rem;background:#ff6b9de6;color:#fff;padding:.5rem 1rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600}.character-stamp.secondary{background:#9b59b6e6}.character-stamp.practical{background:#06b6d4e6}.stamp-avatar{width:20px;height:20px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:.7rem}.re-property-info{padding:1.5rem}.property-title{font-size:1.3rem;font-weight:600;color:var(--re-text-primary);margin-bottom:.75rem;line-height:1.3}.property-details{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.detail{background:var(--re-bg-light);color:var(--re-text-primary);padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:500}.property-price{margin-bottom:1rem}.price-main{display:block;font-size:1.5rem;font-weight:700;color:var(--re-accent-blue);margin-bottom:.25rem}.price-sub{font-size:.8rem;color:var(--re-text-muted)}.property-analysis{display:flex;justify-content:space-between;padding:1rem;background:var(--re-bg-light);border-radius:10px;margin:-.5rem -1.5rem -1.5rem}.analysis-item{text-align:center;flex:1}.analysis-label{display:block;font-size:.7rem;color:var(--re-text-muted);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.analysis-value{font-size:1.1rem;font-weight:600;color:var(--re-text-primary)}.analysis-value.highlight{color:var(--re-accent-green)}.room-exploration-section{margin-top:2rem}.exploration-header{background:var(--re-bg-white);border-radius:20px;padding:2rem;box-shadow:var(--re-shadow-lg);border:1px solid var(--re-border);margin-bottom:2rem;text-align:center}.exploration-title{font-size:2rem;font-weight:700;color:var(--re-text-primary);margin-bottom:1rem;font-family:Playfair Display,serif}.character-commentary{background:linear-gradient(135deg,#ff6b9d1a,#ff6b9d0d);border:1px solid rgba(255,107,157,.2);border-radius:15px;padding:1rem 1.5rem;display:inline-block;margin:0 auto}.commentary-text{color:var(--re-text-primary);font-size:1.1rem;font-weight:500;line-height:1.5}.explore-hint{margin-top:1.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;animation:bounce 2s infinite}.hint-arrow{font-size:1.5rem;color:var(--re-accent-blue)}.hint-text{color:var(--re-text-secondary);font-size:.95rem;font-weight:500}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.room-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.room-card{background:var(--re-bg-white);border:1px solid var(--re-border);border-radius:15px;overflow:hidden;cursor:pointer;transition:var(--re-transition);position:relative;box-shadow:var(--re-shadow)}.room-card:hover{transform:translateY(-5px);box-shadow:var(--re-shadow-xl);border-color:var(--re-accent-blue)}.room-image-container{position:relative;height:200px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1)}.room-image-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:3rem}.room-badges{position:absolute;top:1rem;left:1rem;display:flex;gap:.5rem;flex-wrap:wrap}.badge{padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600;color:#fff;background:var(--re-accent-blue)}.badge.new{background:var(--re-accent-green)}.badge.featured{background:var(--re-accent-gold)}.character-reaction{position:absolute;bottom:1rem;right:1rem;background:#ff6b9de6;color:#fff;padding:.5rem 1rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600}.reaction-emoji{font-size:1.2rem}.room-title{font-size:1.3rem;font-weight:600;color:var(--re-text-primary);margin-bottom:.5rem;line-height:1.3}.room-tagline{color:var(--re-text-secondary);font-size:.9rem;margin-bottom:1rem;font-style:italic}.room-features{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.feature{background:var(--re-bg-light);color:var(--re-text-primary);padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:500}.room-appeal{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.appeal-meter{display:flex;flex-direction:column;gap:.25rem}.appeal-label{font-size:.8rem;color:var(--re-text-muted)}.heart{color:#e5e7eb;font-size:1rem}.heart.filled{color:#ff6b9d}.explore-btn{background:var(--re-accent-blue);color:#fff;border:none;padding:.5rem 1rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;font-weight:600;cursor:pointer;transition:var(--re-transition)}.explore-btn:hover{background:#2563eb;transform:translate(2px)}.btn-arrow{transition:transform .2s ease}.explore-btn:hover .btn-arrow{transform:translate(3px)}.property-section{background:var(--re-bg-white);border-radius:20px;padding:2rem;box-shadow:var(--re-shadow-lg);border:1px solid var(--re-border)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--re-text-primary);font-family:Playfair Display,serif}.search-controls{display:flex;gap:1rem;align-items:center}.search-input{padding:.75rem 1rem;border:1px solid var(--re-border);border-radius:10px;font-size:.9rem;background:var(--re-bg-light);transition:var(--re-transition);width:200px}.search-input:focus{outline:none;border-color:var(--re-accent-blue);background:#fff;box-shadow:0 0 0 3px #3b82f61a}.filter-btn{padding:.75rem 1rem;background:var(--re-bg-light);border:1px solid var(--re-border);border-radius:10px;cursor:pointer;transition:var(--re-transition);font-size:.9rem;font-weight:500;color:var(--re-text-secondary)}.filter-btn:hover{background:var(--re-accent-blue);color:#fff;border-color:var(--re-accent-blue)}.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.property-card{background:var(--re-bg-white);border:1px solid var(--re-border);border-radius:15px;overflow:hidden;cursor:pointer;transition:var(--re-transition);position:relative}.property-card:hover{transform:translateY(-5px);box-shadow:var(--re-shadow-xl);border-color:var(--re-accent-blue)}.property-image{height:200px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--re-text-muted);position:relative}.property-image:after{content:"🏢";font-size:4rem;opacity:.3}.property-badge{position:absolute;top:1rem;right:1rem;background:var(--re-accent-green);color:#fff;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600}.property-info{padding:1.5rem}.property-title{font-size:1.2rem;font-weight:600;color:var(--re-text-primary);margin-bottom:.5rem;line-height:1.3}.property-location{color:var(--re-text-secondary);font-size:.9rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.property-details{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.detail-item{text-align:center}.detail-label{color:var(--re-text-muted);font-size:.8rem;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.detail-value{color:var(--re-text-primary);font-weight:600;font-size:1rem}.property-price{text-align:center;padding:1rem;background:var(--re-bg-light);border-top:1px solid var(--re-border)}.price-label{color:var(--re-text-muted);font-size:.8rem;margin-bottom:.25rem}.price-value{color:var(--re-accent-blue);font-size:1.5rem;font-weight:700}.re-sidebar{display:flex;flex-direction:column;gap:1.5rem}.sidebar-section{background:var(--re-bg-white);border-radius:15px;padding:1.5rem;box-shadow:var(--re-shadow);border:1px solid var(--re-border)}.sidebar-title{font-size:1.2rem;font-weight:600;color:var(--re-text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.recommendation-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--re-bg-light);border-radius:10px;margin-bottom:1rem;cursor:pointer;transition:var(--re-transition)}.recommendation-item:hover{background:#3b82f60d;border-color:var(--re-accent-blue)}.rec-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#f8b500)}.rec-content{flex:1}.rec-title{font-weight:600;color:var(--re-text-primary);font-size:.9rem;margin-bottom:.25rem}.rec-description{color:var(--re-text-secondary);font-size:.8rem;line-height:1.4}.property-detail-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:var(--re-transition)}.property-detail-modal.active{opacity:1;visibility:visible}.modal-content{background:var(--re-bg-white);border-radius:20px;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .4s ease-out}@keyframes modalSlideIn{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:2rem;border-bottom:1px solid var(--re-border);display:flex;justify-content:space-between;align-items:flex-start}.modal-close{width:40px;height:40px;border-radius:50%;background:var(--re-bg-light);border:1px solid var(--re-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--re-transition);color:var(--re-text-secondary)}.modal-close:hover{background:#ef4444;color:#fff;border-color:#ef4444}.modal-property-info h2{font-size:1.8rem;font-weight:700;color:var(--re-text-primary);margin-bottom:.5rem;font-family:Playfair Display,serif}.modal-property-location{color:var(--re-text-secondary);font-size:1rem;display:flex;align-items:center;gap:.5rem}.modal-body{padding:2rem}.property-specs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.spec-item{text-align:center;padding:1rem;background:var(--re-bg-light);border-radius:10px}.spec-label{color:var(--re-text-muted);font-size:.8rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.spec-value{color:var(--re-text-primary);font-weight:600;font-size:1.1rem}.character-opinions{margin-top:2rem}.opinions-title{font-size:1.3rem;font-weight:600;color:var(--re-text-primary);margin-bottom:1.5rem;font-family:Playfair Display,serif}.opinion-item{display:flex;gap:1rem;padding:1.5rem;background:var(--re-bg-light);border-radius:15px;margin-bottom:1rem;border-left:4px solid var(--re-accent-blue)}.opinion-avatar{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#f8b500);flex-shrink:0}.opinion-content{flex:1}.opinion-author{font-weight:600;color:var(--re-text-primary);margin-bottom:.5rem;font-size:1rem}.opinion-text{color:var(--re-text-secondary);line-height:1.6;font-size:.95rem}.modal-actions{padding:2rem;border-top:1px solid var(--re-border);display:flex;gap:1rem;justify-content:flex-end}.action-btn{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:var(--re-transition);border:none;font-size:.95rem}.btn-primary{background:var(--re-accent-blue);color:#fff}.btn-primary:hover{background:#2563eb;transform:translateY(-1px)}.btn-secondary{background:var(--re-bg-light);color:var(--re-text-secondary);border:1px solid var(--re-border)}.btn-secondary:hover{background:var(--re-text-secondary);color:#fff}@media (max-width: 1024px){.re-main{grid-template-columns:1fr;gap:1.5rem}.re-sidebar{order:-1}}@media (max-width: 768px){.re-header{padding:1rem}.re-header-content{flex-direction:column;gap:1rem;align-items:flex-start}.re-main{padding:1rem}.property-grid{grid-template-columns:1fr}.search-controls{flex-direction:column;width:100%}.search-input{width:100%}.modal-content{width:95%;margin:1rem}.modal-header,.modal-body,.modal-actions{padding:1.5rem}.property-specs{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.property-details,.property-specs{grid-template-columns:1fr}.modal-actions{flex-direction:column}.action-btn{width:100%}}:root{--transition-fast: .2s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .6s cubic-bezier(.68, -.55, .265, 1.55)}.app-container{position:relative;width:100%;height:100vh;overflow:hidden}.mode-container{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;visibility:hidden;transform:translate(100%);transition:all var(--transition-slow);z-index:1}.mode-container.active{opacity:1;visibility:visible;transform:translate(0);z-index:10}.modern-mode{transform:translateY(-50px)}.modern-mode.active{transform:translateY(0)}.visual-novel-mode{transform:translate(-100%)}.visual-novel-mode.active{transform:translate(0)}.real-estate-mode{transform:scale(.9) translateY(50px)}.real-estate-mode.active{transform:scale(1) translateY(0)}.transition-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ff6b9df2,#c44569f2,#f8b500f2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;pointer-events:none;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.transition-overlay.active{opacity:1;visibility:visible;pointer-events:auto}.transition-overlay.effect-fade{animation:overlayFadeIn .8s ease-out}.transition-overlay.effect-slide{animation:overlaySlideIn .8s cubic-bezier(.25,.46,.45,.94)}.transition-overlay.effect-scale{animation:overlayScaleIn .8s cubic-bezier(.34,1.56,.64,1)}@keyframes overlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}}@keyframes overlaySlideIn{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes overlayScaleIn{0%{transform:scale(1.3);opacity:0}to{transform:scale(1);opacity:1}}.transition-content{text-align:center;color:#fff;max-width:400px;padding:2rem}.transition-spinner{width:80px;height:80px;margin:0 auto 2rem;position:relative}.spinner-ring{position:absolute;width:100%;height:100%;border:3px solid transparent;border-top:3px solid rgba(255,255,255,.8);border-radius:50%;animation:spin 1s linear infinite}.spinner-ring:nth-child(2){width:60px;height:60px;top:10px;left:10px;border-top-color:#fff9;animation-duration:1.5s;animation-direction:reverse}.spinner-ring:nth-child(3){width:40px;height:40px;top:20px;left:20px;border-top-color:#fff6;animation-duration:2s}.spinner-progress{position:absolute;width:90px;height:90px;top:-5px;left:-5px;border-radius:50%;background:conic-gradient(rgba(255,255,255,.9) calc(var(--progress, 0) * 3.6deg),transparent 0);mask:radial-gradient(transparent 35px,black 35px);-webkit-mask:radial-gradient(transparent 35px,black 35px);transition:background .1s linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.transition-text{font-size:1.3rem;font-weight:600;margin-bottom:1rem;font-family:Playfair Display,serif;animation:fadeInUp .6s ease-out}.transition-subtitle{font-size:1rem;opacity:.8;animation:fadeInUp .6s ease-out .2s both}.transition-progress-bar{width:200px;height:4px;background:#fff3;border-radius:2px;margin:1.5rem auto 0;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#fffc,#fff,#fffc);border-radius:2px;transition:width .1s linear;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-dots{display:inline-flex;gap:.25rem;margin-left:.5rem}.loading-dot{width:6px;height:6px;border-radius:50%;background:#fff9;animation:loadingDot 1.4s ease-in-out infinite both}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}.loading-dot:nth-child(3){animation-delay:0s}@keyframes loadingDot{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideInDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounceOut{20%{transform:scale(.9)}50%,55%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(.3)}}.animate-fadeIn{animation:fadeIn var(--transition-normal) ease-out}.animate-fadeInUp{animation:fadeInUp var(--transition-normal) ease-out}.animate-fadeInDown{animation:fadeInDown var(--transition-normal) ease-out}.animate-fadeInLeft{animation:fadeInLeft var(--transition-normal) ease-out}.animate-fadeInRight{animation:fadeInRight var(--transition-normal) ease-out}.animate-scaleIn{animation:scaleIn var(--transition-normal) ease-out}.animate-bounceIn{animation:bounceIn var(--transition-bounce) ease-out}.animate-slideInLeft{animation:slideInLeft var(--transition-normal) ease-out}.animate-slideInRight{animation:slideInRight var(--transition-normal) ease-out}.animate-slideInUp{animation:slideInUp var(--transition-normal) ease-out}.animate-slideInDown{animation:slideInDown var(--transition-normal) ease-out}.animate-delay-100{animation-delay:.1s}.animate-delay-200{animation-delay:.2s}.animate-delay-300{animation-delay:.3s}.animate-delay-500{animation-delay:.5s}.animate-delay-700{animation-delay:.7s}.animate-delay-1000{animation-delay:1s}.stagger-children>*{animation:fadeInUp var(--transition-normal) ease-out both}.stagger-children>*:nth-child(1){animation-delay:.1s}.stagger-children>*:nth-child(2){animation-delay:.2s}.stagger-children>*:nth-child(3){animation-delay:.3s}.stagger-children>*:nth-child(4){animation-delay:.4s}.stagger-children>*:nth-child(5){animation-delay:.5s}.stagger-children>*:nth-child(6){animation-delay:.6s}.hover-lift{transition:transform var(--transition-fast)}.hover-lift:hover{transform:translateY(-5px)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:box-shadow var(--transition-fast)}.hover-glow:hover{box-shadow:0 10px 30px #ff6b9d4d}.page-enter{opacity:0;transform:translate(100%)}.page-enter-active{opacity:1;transform:translate(0);transition:all var(--transition-slow)}.page-exit{opacity:1;transform:translate(0)}.page-exit-active{opacity:0;transform:translate(-100%);transition:all var(--transition-slow)}.modal-enter{opacity:0;transform:scale(.8)}.modal-enter-active{opacity:1;transform:scale(1);transition:all var(--transition-normal)}.modal-exit{opacity:1;transform:scale(1)}.modal-exit-active{opacity:0;transform:scale(.8);transition:all var(--transition-normal)}.backdrop-enter{opacity:0}.backdrop-enter-active{opacity:1;transition:opacity var(--transition-normal)}.backdrop-exit{opacity:1}.backdrop-exit-active{opacity:0;transition:opacity var(--transition-normal)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.transition-overlay,.mode-container{transition:opacity .1s}}.mode-container,.transition-overlay{will-change:transform,opacity}.character-card-modern,.property-card,.choice-btn{will-change:transform}.gpu-accelerated{transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.modern-content,.visual-novel-content,.real-estate-content{width:100%;height:100%;position:relative;overflow:auto}.mode-container{will-change:transform,opacity}.mode-container.modern-mode,.mode-container.visual-novel-mode,.mode-container.real-estate-mode{transition:all .8s cubic-bezier(.25,.46,.45,.94)}.mode-container:not(.active){pointer-events:none}.mode-container.modern-mode:not(.active){transform:translateY(-50px) scale(.95);opacity:0}.mode-container.visual-novel-mode:not(.active){transform:translate(-100%) scale(.9);opacity:0}.mode-container.real-estate-mode:not(.active){transform:translateY(50px) scale(.95);opacity:0}.game-title-screen{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b9d,#c44569,#774c60);overflow:hidden}.title-background{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.floating-hearts-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.floating-hearts-bg:before,.floating-hearts-bg:after{content:"💕 💖 💝 💗 💓";position:absolute;font-size:2rem;opacity:.1;animation:floatHearts 20s linear infinite}.floating-hearts-bg:after{animation-delay:10s;left:50%}@keyframes floatHearts{0%{transform:translateY(100vh) rotate(0)}to{transform:translateY(-100vh) rotate(360deg)}}.title-particles{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.05) 0%,transparent 50%)}.game-title-content{position:relative;z-index:1;text-align:center;animation:fadeInUp 1s ease-out}.game-logo-container{margin-bottom:3rem}.game-title{display:flex;flex-direction:column;align-items:center;gap:.5rem}.title-main{font-size:var(--text-7xl);font-weight:var(--font-weight-bold);color:#fff;text-shadow:0 0 30px rgba(255,255,255,.5),0 4px 8px rgba(0,0,0,.3);letter-spacing:var(--tracking-widest);animation:titleGlow 3s ease-in-out infinite}.title-sub{font-size:var(--text-2xl);font-weight:var(--font-weight-regular);color:#ffffffe6;font-style:italic}.game-tagline{font-size:var(--text-xl);font-weight:var(--font-weight-light);color:#fffc;margin-top:1rem;animation:fadeIn 2s ease-out .5s both}@keyframes titleGlow{0%,to{text-shadow:0 0 30px rgba(255,255,255,.5),0 4px 8px rgba(0,0,0,.3)}50%{text-shadow:0 0 50px rgba(255,255,255,.8),0 4px 12px rgba(0,0,0,.4)}}.game-menu{display:flex;flex-direction:column;gap:1rem;margin-top:3rem}.game-menu-item{display:flex;align-items:center;gap:1rem;padding:1rem 3rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);border-radius:50px;color:#fff;font-size:var(--text-lg);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:280px}.game-menu-item:hover:not(.disabled){background:#fff3;border-color:#ffffff80;transform:translate(10px);box-shadow:0 8px 32px #0003}.game-menu-item.primary{background:#fff3;border-color:#fff;font-weight:var(--font-weight-semibold)}.game-menu-item.disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d}.game-menu-item.disabled .menu-icon,.game-menu-item.disabled .menu-text,.game-menu-item.disabled .menu-subtitle{color:#fff6}.game-menu-item.disabled:hover{transform:none;background:#ffffff0d;border-color:#fff3}.menu-icon{font-size:1.5rem}.menu-text{flex:1;font-weight:var(--font-weight-medium)}.menu-subtitle{font-size:var(--text-sm);font-weight:var(--font-weight-regular);opacity:.7}.game-version{margin-top:3rem;font-size:var(--text-sm);font-weight:var(--font-weight-regular);color:#ffffff80;display:flex;gap:1rem;align-items:center}.route-selection-screen{background:linear-gradient(180deg,#2d1b69,#0f0c29);min-height:100vh;padding:2rem}.route-title{font-size:var(--text-4xl);font-weight:var(--font-weight-bold);text-align:center;color:#fff;margin-bottom:.5rem;text-shadow:0 2px 8px rgba(0,0,0,.3)}.route-subtitle{text-align:center;color:#fffc;font-size:var(--text-lg);font-weight:var(--font-weight-regular);margin-bottom:3rem}.route-card{position:relative;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:20px;overflow:hidden;transition:all .4s ease;cursor:pointer}.route-card:hover{transform:translateY(-10px);border-color:#ffffff4d;box-shadow:0 20px 40px #0000004d}.route-card.route-selected{animation:routeSelect .6s ease-out;border-color:#ff6b9d;box-shadow:0 0 50px #ff6b9d80}@keyframes routeSelect{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.route-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#c44569f2,#ff6b9df2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:var(--text-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-wide);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #c445694d;border:1px solid rgba(255,255,255,.2)}.portrait-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.portrait-frame{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid rgba(255,255,255,.1);border-radius:18px 18px 0 0}.character-name{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);color:#2c3e50;margin-bottom:.25rem}.character-title{font-size:var(--text-sm);color:#34495e;font-style:italic;margin-bottom:1rem;font-weight:var(--font-weight-semibold)}.character-details{display:flex;gap:1rem;margin-bottom:1rem;font-size:.85rem;color:#2c3e50;font-weight:500;justify-content:center}.character-catchphrase{font-size:1rem;color:#c44569;font-style:italic;margin:1rem 0;line-height:1.4;font-weight:600}.affection-meter{display:flex;align-items:center;gap:.5rem;margin-top:1rem}.meter-label{font-size:.9rem;color:#ffffffb3}.meter-hearts{display:flex;gap:.25rem}.heart{font-size:1.2rem;color:#fff3;transition:all .3s ease}.heart.filled{color:#ff6b9d;animation:heartBeat 1s ease-in-out infinite}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.vn-background{filter:brightness(.7) saturate(1.2)}.vn-character-display{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:800px;height:70%;pointer-events:none}.character-image{width:400px;height:600px;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.3) 100%);border-radius:20px;position:relative;animation:characterFadeIn .5s ease-out}@keyframes characterFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.character-emotion{position:absolute;top:20%;right:-20px;font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));animation:emotionPop .3s ease-out}@keyframes emotionPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.speaker-name{color:#ff6b9d;font-size:1.2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.message-text{font-size:1.1rem;line-height:1.8;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.message-controls{display:flex;gap:1rem;align-items:center;justify-content:flex-end;margin-top:1rem}.skip-btn,.auto-btn,.log-btn{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s ease}.skip-btn:hover,.auto-btn:hover,.log-btn:hover{background:#fff3;border-color:#fff6}.skip-btn.active,.auto-btn.active{background:#ff6b9d4d;border-color:#ff6b9d}.choices-list{display:flex;flex-direction:column;gap:1rem}.affection-display{display:flex;align-items:center;gap:.5rem}.affection-hearts{display:flex;gap:.25rem}.route-progress{display:flex;align-items:center;gap:.5rem}.progress-bar{width:120px;height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#ff6b9d,#c44569);transition:width .5s ease}.date-mode{background:linear-gradient(180deg,#ffeaa7,#fab1a0);min-height:100vh}.date-header{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a;padding:1.5rem 0}.date-header-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}.date-title{font-size:1.8rem;color:#c44569;margin:0}.date-subtitle{font-size:1rem;color:#774c60;margin:.25rem 0 0}.character-mood{display:flex;align-items:center;gap:.5rem}.mood-emoji{font-size:2rem}.date-hearts{display:flex;gap:.25rem}.return-to-story-btn{padding:.75rem 1.5rem;background:#ff6b9d;border:none;border-radius:25px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.return-to-story-btn:hover{background:#c44569;transform:translateY(-2px);box-shadow:0 4px 12px #c445694d}.character-request-box{max-width:800px;margin:3rem auto;padding:0 2rem}.character-bubble{display:flex;align-items:flex-start;gap:1.5rem;margin-bottom:2rem}.bubble-portrait{width:120px;height:120px;border-radius:50%;border:4px solid white;box-shadow:0 4px 12px #0003}.bubble-content{flex:1;background:#fff;padding:1.5rem;border-radius:20px;position:relative;box-shadow:0 4px 20px #0000001a}.bubble-content:before{content:"";position:absolute;left:-10px;top:30px;width:0;height:0;border-style:solid;border-width:10px 10px 10px 0;border-color:transparent white transparent transparent}.bubble-text{font-size:1.1rem;color:#333;line-height:1.6}.preference-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:2rem}.pref-btn{padding:1rem;background:#fff;border:2px solid #ff6b9d;border-radius:15px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem}.pref-btn:hover{background:#ff6b9d;color:#fff;transform:translateY(-5px);box-shadow:0 8px 20px #ff6b9d4d}.pref-btn.selected{background:#ff6b9d;color:#fff;transform:translateY(-3px);box-shadow:0 5px 15px #ff6b9d66}.pref-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pref-icon{font-size:2rem}.filtering-indicator{text-align:center;margin-top:1rem;animation:pulse 1.5s ease-in-out infinite}.loading-text{color:#ff6b9d;font-size:1rem;font-weight:500}.explore-hint{margin-top:1rem;text-align:center;animation:fadeInUp .5s ease-out}.hint-arrow{display:block;font-size:2rem;color:#ff6b9d;animation:bounce 1s ease-in-out infinite}.hint-text{display:block;color:#ff6b9d;font-size:1rem;font-weight:500;margin-top:.5rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}.room-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;max-width:1200px;margin:0 auto;padding:2rem}.room-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #0000001a;transition:all .3s ease;cursor:pointer}.room-card:hover{transform:translateY(-10px);box-shadow:0 12px 40px #00000026}.room-image-container{position:relative;height:250px;overflow:hidden}.room-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.room-badges{position:absolute;top:1rem;left:1rem;display:flex;flex-direction:column;gap:.5rem}.badge{padding:.5rem 1rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;font-size:.85rem;font-weight:600}.badge.romantic{background:#ff6b9de6;color:#fff}.badge.new{background:#ffd700e6;color:#333}.character-reaction{position:absolute;bottom:1rem;right:1rem;background:#fffffff2;padding:.5rem 1rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.reaction-emoji{font-size:1.5rem}.room-info{padding:1.5rem}.room-title{font-size:1.3rem;font-weight:700;color:#333;margin-bottom:.5rem}.room-tagline{font-size:.95rem;color:#666;font-style:italic;margin-bottom:1rem}.room-features{display:flex;gap:1rem;margin-bottom:1rem}.feature{font-size:.85rem;color:#666}.room-appeal{display:flex;align-items:center;justify-content:space-between;margin-top:1rem}.appeal-meter{display:flex;align-items:center;gap:.5rem}.appeal-label{font-size:.9rem;color:#666}.appeal-hearts{display:flex;gap:.25rem}.explore-btn{padding:.75rem 1.5rem;background:#ff6b9d;border:none;border-radius:20px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.explore-btn:hover{background:#c44569;transform:translate(5px)}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-10px)}60%{transform:translate(-50%) translateY(-5px)}}.room-event-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.event-container{background:#fff;border-radius:20px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.event-header{background:linear-gradient(135deg,#ff6b9d,#c44569);padding:1.5rem;display:flex;align-items:center;justify-content:space-between}.event-title{font-size:1.5rem;color:#fff;margin:0}.close-event{width:40px;height:40px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-event:hover{background:#ffffff4d;transform:rotate(90deg)}.event-scene{position:relative;height:400px;overflow:hidden}.scene-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.character-in-scene{position:absolute;bottom:0;right:10%;width:300px;height:400px}.scene-character{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.event-dialogue{padding:2rem}.dialogue-box{background:#f8f9fa;padding:1.5rem;border-radius:15px;margin-bottom:2rem}.room-features-story{margin:2rem 0}.features-title{font-size:1.2rem;color:#333;margin-bottom:1rem}.feature-items{display:flex;flex-direction:column;gap:1rem}.feature-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:10px}.feature-icon{font-size:1.5rem}.choice-prompt{margin-top:2rem}.prompt-text{font-size:1.1rem;color:#666;margin-bottom:1rem;text-align:center}.event-choices{display:flex;flex-direction:column;gap:1rem}.choice-btn.positive{border-color:#ff6b9d}.choice-btn.neutral{border-color:#74b9ff}.choice-btn.romantic{border-color:#fd79a8}.choice-icon{font-size:1.5rem}.game-ui-elements{position:fixed;top:1rem;right:1rem;z-index:100}@media (max-width: 768px){.room-event-modal{padding:.5rem}.event-container{margin:.5rem;max-height:calc(100vh - 1rem)}.event-scene{height:150px!important;min-height:150px!important}.scene-image>div{height:150px!important}.event-choices{grid-template-columns:1fr!important}.choice-btn{padding:.75rem!important;font-size:.85rem!important}.room-features-story{margin-bottom:.5rem!important;padding:.75rem!important}.features-title{font-size:1rem!important}.event-dialogue,.choice-section{padding:1rem!important}}.player-status{background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem;border-radius:15px;display:flex;flex-direction:column;gap:.5rem;min-width:200px}.status-item{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:.9rem}.status-icon{font-size:1.2rem}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.98)}}@keyframes float{0%,to{transform:translateY(0) rotate(0);opacity:1}50%{transform:translateY(-20px) rotate(180deg);opacity:.7}}.animate-float{animation:float 3s ease-in-out infinite}.achievement-gallery{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.achievement-gallery::-webkit-scrollbar{width:8px}.achievement-gallery::-webkit-scrollbar-track{background:#0003}.achievement-gallery::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.achievement-gallery::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@keyframes legendary-pulse{0%,to{box-shadow:0 0 20px #ffd70080}50%{box-shadow:0 0 40px #ffd700cc}}@keyframes epic-pulse{0%,to{box-shadow:0 0 20px #9333ea80}50%{box-shadow:0 0 40px #9333eacc}}@keyframes rare-pulse{0%,to{box-shadow:0 0 20px #3b82f680}50%{box-shadow:0 0 40px #3b82f6cc}}.achievement-legendary{animation:legendary-pulse 2s ease-in-out infinite}.achievement-epic{animation:epic-pulse 2s ease-in-out infinite}.achievement-rare{animation:rare-pulse 2s ease-in-out infinite}.achievement-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,gold,#ffed4e);padding:2rem;border-radius:20px;box-shadow:0 20px 60px #0000004d;animation:achievementPop .5s ease-out}@keyframes achievementPop{0%{transform:translate(-50%,-50%) scale(0)}50%{transform:translate(-50%,-50%) scale(1.1)}to{transform:translate(-50%,-50%) scale(1)}}.achievement-content{display:flex;align-items:center;gap:1.5rem}.achievement-icon{font-size:3rem}.achievement-title{font-size:1.2rem;font-weight:700;color:#333;margin:0}.achievement-desc{font-size:1rem;color:#666;margin:.25rem 0 0}.transition-overlay.romantic{background:radial-gradient(circle at center,#ff6b9dcc,#c44569e6)}.route-start-message{text-align:center;color:#fff}.route-start-message h2{font-size:2.5rem;margin-bottom:1rem;text-shadow:0 4px 12px rgba(0,0,0,.3)}.route-start-message p{font-size:1.2rem;opacity:.9;font-style:italic}@keyframes heartBurst{0%{transform:translate(-50%,-50%) scale(0);opacity:1}to{transform:translate(-50%,-50%) scale(3);opacity:0}}.heart-burst{position:absolute;top:50%;left:50%;font-size:5rem;color:#ff6b9d;animation:heartBurst 1s ease-out forwards;pointer-events:none}@media (max-width: 768px){.game-title-content{padding:1rem}.title-main{font-size:3rem}.game-menu-item{min-width:240px;padding:.75rem 2rem}.room-cards-grid{grid-template-columns:1fr;padding:1rem}.preference-buttons{grid-template-columns:repeat(2,1fr)}.character-bubble{flex-direction:column;align-items:center}.bubble-content:before{display:none}}.save-load-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease}.save-load-overlay.active{opacity:1;visibility:visible}.save-load-container{background:linear-gradient(135deg,#2a2a3e,#1a1a2e);border:2px solid rgba(255,255,255,.1);border-radius:20px;max-width:1200px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000080,0 0 60px #ff6b9d33;animation:slideIn .4s ease-out}@keyframes slideIn{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.save-load-header{padding:2rem 3rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.save-load-title{font-size:2rem;font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(255,107,157,.3);letter-spacing:.1em}.close-button{width:40px;height:40px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease}.close-button:hover{background:#ff6b9d4d;border-color:#ff6b9d80;transform:scale(1.1)}.save-slots-grid{padding:3rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.save-slot{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:15px;overflow:hidden;transition:all .3s ease;position:relative;cursor:pointer}.save-slot.clickable:hover,.save-slot.filled:hover{border-color:#ff6b9d80;background:#ffffff14;transform:translateY(-5px);box-shadow:0 10px 30px #ff6b9d4d}.save-slot.empty{min-height:200px;display:flex;flex-direction:column}.slot-header{padding:1rem 1.5rem;background:#0000004d;display:flex;justify-content:space-between;align-items:center}.slot-number{color:#fffc;font-size:.9rem;font-weight:600;letter-spacing:.05em}.slot-actions{display:flex;gap:.5rem}.delete-button{background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.6;transition:all .3s ease}.delete-button:hover{opacity:1;transform:scale(1.2)}.delete-confirm{display:flex;gap:.5rem}.delete-confirm button{padding:.25rem .75rem;border-radius:5px;border:none;font-size:.8rem;cursor:pointer;transition:all .3s ease}.delete-confirm .confirm-button{background:#ef4444;color:#fff}.delete-confirm .cancel-button{background:#fff3;color:#fff}.empty-slot-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-text{color:#fff9;font-size:1rem}.save-thumbnail{height:150px;background:#00000080;position:relative;overflow:hidden}.save-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.placeholder-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#ff6b9d,#c44569)}.character-avatar{font-size:4rem;z-index:1}.chapter-bg{position:absolute;bottom:10px;right:10px;color:#ffffff4d;font-size:1.5rem;font-weight:700;letter-spacing:.05em}.save-info{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.save-date{color:#fff9;font-size:.85rem}.character-info{display:flex;justify-content:space-between;align-items:center}.character-name{color:#fff;font-weight:600;font-size:1.1rem}.affection-level{color:#ff6b9d;font-weight:600;display:flex;align-items:center;gap:.25rem}.chapter-info{color:#fffc;font-size:.95rem}.play-time{color:#fff9;font-size:.85rem}.slot-hover-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ff6b9d33;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}.hover-action{background:#ff6b9de6;color:#fff;padding:.75rem 2rem;border-radius:30px;font-weight:600;letter-spacing:.05em;box-shadow:0 5px 20px #0000004d}.auto-save-info{padding:1.5rem 3rem;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:1rem;color:#fff9}.auto-save-icon{font-size:1.5rem}.auto-save-text{font-size:.9rem}.keyboard-shortcuts{padding:0 3rem 2rem;text-align:center;color:#fff6;font-size:.85rem}.confirm-dialog{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2100;animation:fadeIn .3s ease}.confirm-content{background:#2a2a3e;border:2px solid rgba(255,255,255,.2);border-radius:15px;padding:2rem 3rem;max-width:400px;text-align:center;box-shadow:0 10px 40px #00000080}.confirm-title{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.confirm-message{color:#fffc;margin-bottom:2rem;line-height:1.6}.confirm-actions{display:flex;gap:1rem;justify-content:center}.confirm-button{padding:.75rem 2rem;border-radius:30px;border:none;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;letter-spacing:.05em}.confirm-button.primary{background:linear-gradient(135deg,#ff6b9d,#c44569);color:#fff}.confirm-button.primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px #ff6b9d66}.confirm-button.secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.confirm-button.secondary:hover{background:#fff3}.save-animation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000e6;border-radius:20px;padding:3rem 4rem;text-align:center;z-index:2200;animation:savePopup 1.5s ease}@keyframes savePopup{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}20%{transform:translate(-50%,-50%) scale(1.1);opacity:1}40%{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-50%) scale(1);opacity:0}}.save-icon-large{font-size:4rem;margin-bottom:1rem;animation:pulse 1s ease infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.save-text{color:#fff;font-size:1.5rem;font-weight:600;letter-spacing:.1em}.quick-save-indicator{position:fixed;top:20px;right:20px;background:#000c;color:#fff;padding:1rem 1.5rem;border-radius:10px;display:flex;align-items:center;gap:.75rem;z-index:1500;animation:slideInRight .5s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.quick-save-indicator.success{border:2px solid #10b981;box-shadow:0 5px 20px #10b9814d}.quick-save-indicator.error{border:2px solid #ef4444;box-shadow:0 5px 20px #ef44444d}.game-menu-bar{position:fixed;top:10px;right:10px;z-index:1000;display:flex;align-items:center;gap:1rem}.menu-quick-controls{display:flex;gap:.5rem}.menu-button{background:#000000b3;color:#fff;border:2px solid rgba(255,255,255,.2);border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;letter-spacing:.05em}.menu-button:hover{background:#ffffff1a;border-color:#fff6}.menu-button.active{background:linear-gradient(135deg,#ff6b9d,#c44569);border-color:#ff6b9d;box-shadow:0 2px 10px #ff6b9d4d}.menu-toggle{background:#000000b3;color:#fff;border:2px solid rgba(255,255,255,.2);border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .3s ease}.menu-toggle:hover{background:#ffffff1a;border-color:#fff6}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#000000e6;border:2px solid rgba(255,255,255,.2);border-radius:10px;min-width:200px;box-shadow:0 5px 20px #00000080;animation:dropdownSlide .3s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{width:100%;padding:.75rem 1rem;background:none;border:none;color:#fff;font-size:.95rem;text-align:left;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.75rem}.menu-item:hover{background:#ffffff1a}.menu-item:first-child{border-radius:8px 8px 0 0}.menu-item:last-child{border-radius:0 0 8px 8px}.menu-icon{font-size:1.1rem}.menu-divider{height:1px;background:#fff3;margin:.25rem 0}.menu-keyboard-hint{position:fixed;bottom:10px;right:10px;background:#000000b3;color:#fff9;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;pointer-events:none}@media (max-width: 768px){.save-slots-grid{grid-template-columns:1fr;padding:1.5rem;gap:1rem}.save-load-container{width:95%;border-radius:15px}.save-load-header{padding:1.5rem}.save-load-title{font-size:1.5rem}.save-thumbnail{height:120px}.confirm-content{padding:1.5rem}.game-menu-bar{top:5px;right:5px}.menu-keyboard-hint{display:none}}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#e5e7eb;border-radius:3px;outline:none;transition:background .3s}input[type=range]:hover{background:#d1d5db}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;-webkit-transition:all .2s;transition:all .2s}input[type=range]::-webkit-slider-thumb:hover{background:#2563eb;transform:scale(1.1)}input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;border:none;-moz-transition:all .2s;transition:all .2s}input[type=range]::-moz-range-thumb:hover{background:#2563eb;transform:scale(1.1)}input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:2px solid #d1d5db;border-radius:50%;margin-right:.25rem;position:relative;cursor:pointer;transition:all .2s}input[type=radio]:checked{border-color:#3b82f6;background-color:#3b82f6}input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:#fff;border-radius:50%}input[type=radio]:hover{border-color:#9ca3af}input[type=radio]:checked:hover{border-color:#2563eb;background-color:#2563eb}.volume-indicator{position:relative;display:inline-flex;align-items:center;gap:.5rem}.volume-bars{display:flex;gap:2px;align-items:flex-end;height:16px}.volume-bar{width:3px;background:#d1d5db;border-radius:1px;transition:background .2s}.volume-bar.active{background:#3b82f6}.settings-section{animation:fade-in .3s ease-out}.settings-section-enter{opacity:0;transform:translateY(10px)}.settings-section-enter-active{opacity:1;transform:translateY(0);transition:all .3s ease-out}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px #0003}input:checked+.toggle-slider{background-color:#3b82f6}input:checked+.toggle-slider:before{transform:translate(24px)}.settings-tab-content{animation:tab-fade-in .3s ease-out}@keyframes tab-fade-in{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.settings-backdrop{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}@media (max-width: 640px){.settings-panel{max-height:100vh;height:100vh;max-width:100vw;width:100vw;border-radius:0}.settings-panel-content{padding:1rem}.settings-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.settings-tab-button{flex-shrink:0;min-width:-moz-fit-content;min-width:fit-content}}.chapter-transition{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .8s ease-in-out}.chapter-transition.fadeIn,.chapter-transition.display{opacity:1}.chapter-transition.fadeOut{opacity:0}.chapter-transition-bg{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,#8a2be2f2,#4b0082fa);overflow:hidden}.chapter-transition-particles{position:absolute;width:100%;height:100%}.chapter-transition-particles.layer-1{opacity:.6}.chapter-transition-particles.layer-2{opacity:.8}.chapter-transition-particles.layer-3{opacity:1}.particle{position:absolute;width:var(--size, 4px);height:var(--size, 4px);background:#ffffffe6;border-radius:50%;left:var(--x);top:var(--y);animation:particle-float 6s infinite ease-in-out;animation-delay:var(--delay);box-shadow:0 0 15px #fff9}.particle.large{background:radial-gradient(circle,#fff,#fff6 70%);animation-duration:8s}.particle.sparkle{width:2px;height:2px;background:#fff;box-shadow:0 0 10px #fff,0 0 20px #fffc,0 0 30px #fff9;animation:sparkle-float 4s infinite ease-in-out}@keyframes particle-float{0%,to{transform:translateY(0) translate(0) scale(0);opacity:0}10%{transform:translateY(-20px) translate(10px) scale(1);opacity:1}50%{transform:translateY(-60px) translate(-10px) scale(1.2);opacity:1}90%{transform:translateY(-120px) translate(5px) scale(1);opacity:1}to{transform:translateY(-150px) translate(0) scale(0);opacity:0}}@keyframes sparkle-float{0%,to{transform:translateY(0) scale(0) rotate(0);opacity:0}25%{transform:translateY(-40px) scale(1.5) rotate(180deg);opacity:1}50%{transform:translateY(-80px) scale(1) rotate(360deg);opacity:.8}75%{transform:translateY(-120px) scale(1.2) rotate(540deg);opacity:1}to{transform:translateY(-160px) scale(0) rotate(720deg);opacity:0}}.chapter-transition-content{position:relative;z-index:1;text-align:center;color:#fff;animation:content-appear .8s ease-out}@keyframes content-appear{0%{transform:scale(.8) translateY(40px);opacity:0}50%{transform:scale(1.05) translateY(-5px);opacity:1}to{transform:scale(1) translateY(0);opacity:1}}.chapter-number{font-size:4rem;font-weight:100;letter-spacing:.2em;margin-bottom:1rem;text-shadow:0 0 30px rgba(255,255,255,.5);animation:number-glow 2s ease-in-out infinite}.chapter-label{font-size:2.5rem;opacity:.8}.chapter-digit{font-size:5rem;font-weight:300;margin:0 .5rem;background:linear-gradient(to bottom,#fff,#e0e0e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent}@keyframes number-glow{0%,to{text-shadow:0 0 30px rgba(255,255,255,.5)}50%{text-shadow:0 0 50px rgba(255,255,255,.8)}}.chapter-title{font-size:2.5rem;font-weight:300;margin:2rem 0;position:relative}.title-text{display:inline-block;letter-spacing:.1em;animation:title-shine 3s ease-in-out infinite;background:linear-gradient(90deg,#fff,#f0f0f0 45%,#fff,#f0f0f0 55%,#fff);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent}@keyframes title-shine{0%{background-position:200% 0}to{background-position:-200% 0}}.chapter-transition.display .chapter-transition-content{animation:content-glow 3s ease-in-out infinite}@keyframes content-glow{0%,to{filter:drop-shadow(0 0 20px rgba(255,255,255,.3))}50%{filter:drop-shadow(0 0 40px rgba(255,255,255,.6))}}.title-underline{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:0;height:2px;background:linear-gradient(90deg,transparent,#fff,transparent);animation:underline-expand 1.5s ease-out .5s forwards}@keyframes underline-expand{to{width:120%}}.chapter-decoration{margin-top:2rem;font-size:1.5rem;opacity:0;animation:decoration-fade 1s ease-out 1s forwards}.decoration-left,.decoration-right{display:inline-block;animation:decoration-rotate 4s linear infinite}.decoration-center{display:inline-block;margin:0 2rem;font-size:2rem;animation:decoration-pulse 2s ease-in-out infinite}@keyframes decoration-fade{to{opacity:.8}}@keyframes decoration-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes decoration-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:1}}@media (max-width: 768px){.chapter-number{font-size:3rem}.chapter-label{font-size:2rem}.chapter-digit{font-size:3.5rem}.chapter-title{font-size:2rem}}.chapter-transition[data-type=event] .chapter-transition-bg{background:radial-gradient(ellipse at center,#ff6b6bf2,#b22222fa)}.chapter-transition[data-type=special] .chapter-transition-bg{background:radial-gradient(ellipse at center,#ffd700f2,#ff8c00fa)}.chapter-transition.chapter-end .chapter-transition-bg{background:radial-gradient(ellipse at center,#141428f2,#000000fa)}.chapter-end-symbol{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-bottom:2rem}.end-kanji{font-size:6rem;font-weight:100;letter-spacing:.5rem;color:#ffffffe6;text-shadow:0 0 20px rgba(255,255,255,.5),0 0 40px rgba(255,255,255,.3),0 0 60px rgba(255,255,255,.2);animation:end-kanji-appear 1.5s ease-out;animation-fill-mode:both}.end-kanji:nth-child(1){animation-delay:.3s}.end-kanji:nth-child(2){animation-delay:.6s}.end-kanji:nth-child(3){animation-delay:.9s}@keyframes end-kanji-appear{0%{transform:translateY(30px) scale(.8);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.chapter-end-subtitle{margin-top:1rem;opacity:0;animation:subtitle-fade 1s ease-out 1.5s forwards}.subtitle-text{font-size:1.8rem;font-weight:300;letter-spacing:.2em;color:#ffffffe6}.chapter-end-message{margin-top:2rem;padding:1.5rem;opacity:0;animation:message-appear 1.5s ease-out 2s forwards;max-width:600px;margin-left:auto;margin-right:auto}.chapter-end-message .quote-mark{font-size:2rem;color:#ffd700b3;vertical-align:middle;margin:0 .5rem}.chapter-end-message .message-text{font-size:1.3rem;font-weight:300;line-height:1.8;color:#fffffff2;font-style:italic;text-shadow:0 0 10px rgba(255,255,255,.3),0 0 20px rgba(255,255,255,.2);letter-spacing:.05em}@keyframes message-appear{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes subtitle-fade{to{opacity:1}}.end-decoration{margin-top:3rem;font-size:2rem;opacity:0;animation:decoration-fade 1s ease-out 2s forwards}.end-decoration .decoration-center{animation:end-pulse 3s ease-in-out infinite}@keyframes end-pulse{0%,to{transform:scale(1) rotate(0);opacity:.6}50%{transform:scale(1.3) rotate(180deg);opacity:1}}.chapter-transition.character-complete .chapter-transition-bg{background:radial-gradient(ellipse at center,#ffd700f2,#ff8c00fa,#ff1493f2 60%,#8a2be2fa);animation:character-complete-bg 6s ease-in-out infinite}@keyframes character-complete-bg{0%,to{background:radial-gradient(ellipse at center,#ffd700f2,#ff8c00fa,#ff1493f2 60%,#8a2be2fa)}33%{background:radial-gradient(ellipse at center,#ff1493f2,#8a2be2fa,#ffd700f2 60%,#ff8c00fa)}66%{background:radial-gradient(ellipse at center,#8a2be2f2,#ff1493fa,#ff8c00f2 60%,#ffd700fa)}}.chapter-transition.character-complete .chapter-transition-particles.layer-4{opacity:.9}.chapter-transition.character-complete .chapter-transition-particles.layer-5{opacity:1}.particle.mega-sparkle{background:radial-gradient(circle,rgba(255,215,0,1) 0%,rgba(255,140,0,.8) 40%,rgba(255,20,147,.6) 70%,transparent 100%);border-radius:50%;box-shadow:0 0 20px #ffd700cc,0 0 40px #ff8c0099,0 0 60px #ff149366;animation:mega-sparkle-float 5s infinite ease-in-out}.particle.ultra-sparkle{width:4px;height:4px;background:#fff;border-radius:50%;box-shadow:0 0 15px gold,0 0 30px #ff8c00cc,0 0 45px #ff149399,0 0 60px #8a2be266;animation:ultra-sparkle-float 3s infinite ease-in-out}@keyframes mega-sparkle-float{0%,to{transform:translateY(0) translate(0) scale(0) rotate(0);opacity:0}15%{transform:translateY(-30px) translate(15px) scale(1.2) rotate(90deg);opacity:1}30%{transform:translateY(-60px) translate(-20px) scale(1.5) rotate(180deg);opacity:1}50%{transform:translateY(-100px) translate(25px) scale(1.8) rotate(270deg);opacity:.8}70%{transform:translateY(-140px) translate(-15px) scale(1.3) rotate(360deg);opacity:1}85%{transform:translateY(-180px) translate(10px) scale(1) rotate(450deg);opacity:1}to{transform:translateY(-220px) translate(0) scale(0) rotate(540deg);opacity:0}}@keyframes ultra-sparkle-float{0%,to{transform:translateY(0) scale(0) rotate(0);opacity:0}20%{transform:translateY(-50px) scale(2) rotate(180deg);opacity:1}40%{transform:translateY(-100px) scale(1.5) rotate(360deg);opacity:.9}60%{transform:translateY(-150px) scale(2.5) rotate(540deg);opacity:1}80%{transform:translateY(-200px) scale(1.8) rotate(720deg);opacity:1}to{transform:translateY(-250px) scale(0) rotate(900deg);opacity:0}}.character-complete-symbol{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:2rem}.complete-kanji{font-size:7rem;font-weight:100;letter-spacing:.8rem;background:linear-gradient(135deg,gold,#ff8c00,#ff1493,#8a2be2,gold);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 30px rgba(255,215,0,.6),0 0 60px rgba(255,140,0,.4),0 0 90px rgba(255,20,147,.3);animation:complete-kanji-appear 2s ease-out,rainbow-gradient 4s ease-in-out infinite;animation-fill-mode:both}.complete-kanji:nth-child(1){animation-delay:.5s,.5s}.complete-kanji:nth-child(2){animation-delay:.8s,.8s}@keyframes complete-kanji-appear{0%{transform:translateY(50px) scale(.5) rotate(-10deg);opacity:0}50%{transform:translateY(-10px) scale(1.1) rotate(5deg);opacity:1}to{transform:translateY(0) scale(1) rotate(0);opacity:1}}@keyframes rainbow-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.character-complete-subtitle{margin-top:1.5rem;opacity:0;animation:complete-subtitle-fade 1.5s ease-out 2s forwards}.character-complete-subtitle .subtitle-text{font-size:2.2rem;font-weight:300;letter-spacing:.3em;background:linear-gradient(90deg,gold,#ff8c00,#ff1493,#8a2be2,gold);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-shift 3s ease-in-out infinite}@keyframes gradient-shift{0%{background-position:0% 50%}to{background-position:200% 50%}}.character-complete-message{margin-top:2.5rem;padding:2rem;opacity:0;animation:complete-message-appear 2s ease-out 2.5s forwards;max-width:700px;margin-left:auto;margin-right:auto}.character-complete-message .message-text{font-size:1.5rem;font-weight:300;line-height:2;background:linear-gradient(90deg,#fff,gold,#fff);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-style:italic;text-shadow:0 0 15px rgba(255,215,0,.4),0 0 30px rgba(255,140,0,.3);letter-spacing:.08em;animation:message-glow 3s ease-in-out infinite}@keyframes complete-message-appear{0%{transform:translateY(30px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes message-glow{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes complete-subtitle-fade{to{opacity:1}}.complete-decoration{margin-top:3rem;font-size:2.5rem;opacity:0;animation:complete-decoration-fade 1.5s ease-out 3s forwards}.complete-decoration .decoration-left,.complete-decoration .decoration-right{animation:star-twinkle 2s ease-in-out infinite}.complete-decoration .decoration-center{animation:sparkle-burst 1.5s ease-in-out infinite;font-size:3rem}@keyframes complete-decoration-fade{to{opacity:1}}@keyframes star-twinkle{0%,to{transform:scale(1) rotate(0);opacity:.8;text-shadow:0 0 15px rgba(255,215,0,.6)}50%{transform:scale(1.3) rotate(180deg);opacity:1;text-shadow:0 0 25px rgba(255,215,0,.8)}}@keyframes sparkle-burst{0%,to{transform:scale(1);opacity:.9;text-shadow:0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,140,0,.6)}50%{transform:scale(1.5);opacity:1;text-shadow:0 0 30px rgba(255,215,0,1),0 0 60px rgba(255,140,0,.8),0 0 90px rgba(255,20,147,.6)}}.completion-status{margin-top:2rem;opacity:0;animation:status-appear 2s ease-out 3.5s forwards}.status-text{font-size:1.6rem;font-weight:400;letter-spacing:.1em;background:linear-gradient(45deg,gold,#ff8c00,#ff1493,#8a2be2);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:celebration-glow 2s ease-in-out infinite;text-shadow:0 0 20px rgba(255,215,0,.5)}@keyframes status-appear{0%{transform:translateY(20px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes celebration-glow{0%,to{background-position:0% 50%;text-shadow:0 0 20px rgba(255,215,0,.5)}50%{background-position:100% 50%;text-shadow:0 0 30px rgba(255,215,0,.8)}}@media (max-width: 768px){.complete-kanji{font-size:5rem;letter-spacing:.5rem}.character-complete-subtitle .subtitle-text{font-size:1.8rem}.character-complete-message .message-text{font-size:1.2rem}.status-text{font-size:1.3rem}}@media (max-width: 768px){html{font-size:14px}button,a,[role=button],.clickable{min-height:48px;min-width:48px;padding:12px 16px}.small-button,.icon-button{padding:14px}.visual-novel-text{font-size:1.1rem;line-height:1.8;padding:1.5rem}.choice-btn{padding:16px 24px;font-size:1rem;margin:8px 0;width:100%;max-width:none}.character-message{padding:16px;font-size:1rem;word-wrap:break-word;overflow-wrap:break-word}.character-card-modern{width:100%;max-width:350px;margin:0 auto 16px}.character-grid{grid-template-columns:1fr;gap:16px;padding:16px}.help-menu-container{height:auto;max-height:95vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.help-content{overflow-y:auto;max-height:calc(95vh - 120px)}.property-card{width:100%;margin-bottom:16px;overflow:visible}.property-card .property-description{word-wrap:break-word;overflow-wrap:break-word}.property-grid{grid-template-columns:1fr;padding:16px}.settings-panel{width:100%;height:auto;border-radius:0;max-height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-content{padding:16px;overflow-y:auto;max-height:calc(100vh - 100px)}.save-load-modal,.save-load-container{width:100%;height:auto;max-width:100%;max-height:100vh;border-radius:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.save-slots-grid{grid-template-columns:1fr;gap:12px;padding:16px}.achievement-popup{right:16px;left:16px;width:auto;max-width:none}.game-menu{flex-direction:column;padding:16px}.game-menu-item{width:100%;margin:8px 0;padding:16px;font-size:1.1rem}.modal-overlay{padding:0}.modal-content{width:100%;height:auto;max-width:100%;max-height:100vh;border-radius:0;margin:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}input[type=text],textarea{font-size:16px;padding:12px 16px}.debug-overlay{bottom:70px;left:16px;right:16px;max-width:none}}@media (max-width: 768px) and (orientation: landscape){.visual-novel-text-area{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.message-text{word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.dialogue-box{max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.game-container{padding-top:8px;padding-bottom:8px}}@media (max-width: 375px){html{font-size:13px}.visual-novel-text{padding:1rem}button,.choice-btn{font-size:.95rem}}@media (max-width: 768px){p,span,div,h1,h2,h3,h4,h5,h6,.text-content,.description,.message,.property-description,.character-description{word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.content-container,.text-container,.modal-body,.panel-content{overflow-y:auto;-webkit-overflow-scrolling:touch}.japanese-text,[lang=ja]{word-break:break-word;line-break:strict}}.achievement-toast{background:#000000f2!important}.achievement-rarity-badge{color:#000000e6!important;font-weight:600;text-shadow:0 1px 2px rgba(255,255,255,.3)}.visual-novel-text{color:#fffffff2;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.choice-btn{background:#000c;color:#fffffff2;border:2px solid rgba(255,255,255,.3)}.choice-btn:hover{background:#000000e6;border-color:#ffffff80}.character-name{color:#f8b500;text-shadow:2px 2px 4px rgba(0,0,0,.8);font-weight:600}.settings-label{color:#fffffff2;font-weight:500}.settings-value{color:#fffc}.save-slot{background:#000000b3;color:#ffffffe6}.save-slot-empty{background:#00000080;color:#fff9}.game-menu-item{background:#000c;color:#fffffff2;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.debug-panel{background:#0a0a0afa!important;color:#fffffff2!important}.debug-panel-label{color:#fffc;font-weight:500}.debug-panel-value{color:#fffffff2}button,.choice-btn,.game-menu-item,.character-card-modern{transition:all .2s ease-out;transform:translateZ(0)}button:hover,.choice-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}button:active,.choice-btn:active{transform:translateY(0);transition-duration:.05s}.character-card-modern:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0006}.property-card:hover{transform:scale(1.02);box-shadow:0 6px 20px #0000004d}.fade-enter{opacity:0;transition:opacity .3s ease-in}.fade-enter-active{opacity:1}.fade-exit{opacity:1;transition:opacity .3s ease-out}.fade-exit-active{opacity:0}.modal-overlay{transition:opacity .3s ease}.modal-content{transition:transform .3s ease,opacity .3s ease}.modal-enter .modal-content{transform:scale(.9);opacity:0}.modal-enter-active .modal-content{transform:scale(1);opacity:1}@keyframes achievement-slide-in{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.achievement-enter{animation:achievement-slide-in .4s ease-out}.loading{position:relative;overflow:hidden}.loading:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:loading-shimmer 2s infinite}@keyframes loading-shimmer{to{left:100%}}.ripple{position:relative;overflow:hidden}.ripple:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}.ripple:active:before{width:300px;height:300px}.spacing-xs{margin:4px}.spacing-sm{margin:8px}.spacing-md{margin:16px}.spacing-lg{margin:24px}.spacing-xl{margin:32px}.padding-xs{padding:4px}.padding-sm{padding:8px}.padding-md{padding:16px}.padding-lg{padding:24px}.padding-xl{padding:32px}.interactive{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.interactive:active{opacity:.8}@media (hover: none) and (pointer: coarse){button:hover,.choice-btn:hover,.character-card-modern:hover{transform:none;box-shadow:none}button:active,.choice-btn:active{transform:scale(.95);opacity:.8}}*:focus{outline:none}*:focus-visible{outline:3px solid var(--focus-color, #4169e1);outline-offset:2px;border-radius:4px;box-shadow:0 0 0 6px #4169e140;transition:outline-offset .15s ease,box-shadow .15s ease}:root{--focus-color: #4169e1;--focus-color-danger: #e74c3c;--focus-color-success: #27ae60;--focus-color-warning: #f39c12}button:focus-visible,a:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--focus-color);outline-offset:2px;box-shadow:0 0 0 5px #4169e14d;z-index:1}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--focus-color);outline-offset:0;box-shadow:0 0 0 3px #4169e126}.character-card-modern:focus-visible{outline:3px solid var(--accent-gold, #f8b500);outline-offset:4px;transform:translateY(-5px)}.choice-btn:focus-visible{outline:3px solid var(--accent-gold, #f8b500);outline-offset:2px;transform:scale(1.05)}.game-menu-item:focus-visible{outline:3px solid white;outline-offset:-2px;transform:translate(10px)}.achievement-button:focus-visible,.help-button:focus-visible{outline:3px solid var(--focus-color);outline-offset:2px;transform:scale(1.1)}.close-button:focus-visible,[aria-label*=Close]:focus-visible{outline:3px solid var(--focus-color-danger);outline-offset:2px}.skip-to-content{position:absolute;top:-40px;left:0;background:#2c3e50;color:#fff;padding:8px 16px;text-decoration:none;border-radius:0 0 4px;z-index:100000;transition:top .2s ease}.skip-to-content:focus{top:0}@media (prefers-contrast: high){*:focus-visible{outline-width:4px;outline-style:solid}button:focus-visible,a:focus-visible{outline-color:currentColor}}@media (prefers-reduced-motion: reduce){*:focus-visible{transition:none;animation:none}}button,a,[role=button],[tabindex="0"],input[type=checkbox],input[type=radio],.clickable,.interactive{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;position:relative}button.icon-button,a.icon-link,.small-interactive{padding:8px;min-width:44px;min-height:44px}.small-button{padding:12px}input[type=checkbox],input[type=radio]{position:relative;cursor:pointer}input[type=checkbox]:before,input[type=radio]:before{content:"";position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-trap{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}[aria-busy=true]{cursor:wait;opacity:.7}[disabled],[aria-disabled=true]{cursor:not-allowed;opacity:.6;filter:grayscale(50%)}[aria-invalid=true]{border-color:var(--focus-color-danger)!important}[aria-invalid=true]:focus-visible{outline-color:var(--focus-color-danger);box-shadow:0 0 0 3px #e74c3c26}[aria-valid=true]{border-color:var(--focus-color-success)!important}[aria-valid=true]:focus-visible{outline-color:var(--focus-color-success);box-shadow:0 0 0 3px #27ae6026}[aria-live=polite],[aria-live=assertive]{position:relative}[role=tooltip]{position:absolute;z-index:10000;padding:8px 12px;background:#000000e6;color:#fff;border-radius:4px;font-size:14px;pointer-events:none}[role=progressbar]{position:relative;height:8px;background:#0000001a;border-radius:4px;overflow:hidden}[role=progressbar]:after{content:"";position:absolute;top:0;left:0;height:100%;background:var(--accent-gold, #f8b500);transition:width .3s ease;width:var(--progress, 0%)}.debug-toggle-button{pointer-events:auto}.debug-toggle-button:focus-visible{outline:3px solid #4169e1;outline-offset:2px;box-shadow:0 0 0 6px #4169e14d}.debug-toggle-button:hover{transform:scale(1.1);background:#000000e6!important;border-color:#fff6!important}.debug-toggle-button:active{transform:scale(.95)}.debug-panel{font-feature-settings:"tnum" 1,"zero" 1;letter-spacing:.02em}.debug-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.08)}.debug-item:last-child{border-bottom:none}.debug-label{color:#fff9;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.debug-value{color:#fffffff2;font-weight:600;font-size:13px;text-align:right}.debug-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid rgba(255,255,255,.15)}.debug-panel-title{font-weight:700;font-size:15px;color:#fffffff2;letter-spacing:.02em;text-transform:uppercase}.debug-close-button:hover{background:#fff3!important;transform:scale(1.1)}.debug-close-button:active{transform:scale(.9)}.debug-conversation-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.15)}.debug-conversation-title{font-weight:700;color:#fffffff2;margin-bottom:8px;font-size:14px}@media (max-width: 768px){.debug-panel{bottom:70px!important;left:16px!important;right:16px!important;max-width:none!important;font-size:12px!important}.debug-toggle-button{bottom:70px!important;right:16px!important}.debug-label{font-size:11px}.debug-value{font-size:12px}}@media (max-width: 768px) and (orientation: landscape){.debug-panel{bottom:20px!important;max-height:80vh;overflow-y:auto}.debug-toggle-button{bottom:20px!important}}@media (max-width: 375px){.debug-panel{padding:12px!important;min-width:unset!important}.debug-panel-title{font-size:13px}}@media (prefers-contrast: high){.debug-panel{border:2px solid white!important}.debug-label{color:#fffc}.debug-value{color:#fff}}@keyframes debug-slide-in{0%{transform:translate(-100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.debug-panel{animation:debug-slide-in .3s ease-out}.debug-panel::-webkit-scrollbar{width:4px}.debug-panel::-webkit-scrollbar-track{background:#ffffff0d}.debug-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.debug-panel::-webkit-scrollbar-thumb:hover{background:#ffffff4d}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Noto Sans JP,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.bottom-4{bottom:1rem}.left-4{left:1rem}.right-4{right:1rem}.top-1{top:.25rem}.top-4{top:1rem}.z-40{z-index:40}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-4{margin-left:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-16{width:4rem}.w-24{width:6rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-full{width:100%}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-sm{max-width:24rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-1{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-6{--tw-translate-x: 1.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x: 100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-24{--tw-translate-y: 6rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-95{--tw-scale-x: .95;--tw-scale-y: .95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes float{0%,to{transform:translate(0) translateY(0) rotate(0)}33%{transform:translate(-20px) translateY(-10px) rotate(1deg)}66%{transform:translate(10px) translateY(-20px) rotate(-1deg)}}.animate-float{animation:float 20s ease-in-out infinite}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-blue-400{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-purple-400{--tw-border-opacity: 1;border-color:rgb(192 132 252 / var(--tw-border-opacity, 1))}.border-yellow-400{--tw-border-opacity: 1;border-color:rgb(250 204 21 / var(--tw-border-opacity, 1))}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-black\/50{background-color:#00000080}.bg-black\/90{background-color:#000000e6}.bg-blue-400\/10{background-color:#60a5fa1a}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-400\/10{background-color:#9ca3af1a}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-950{--tw-bg-opacity: 1;background-color:rgb(3 7 18 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-pink-500{--tw-bg-opacity: 1;background-color:rgb(236 72 153 / var(--tw-bg-opacity, 1))}.bg-purple-400\/10{background-color:#c084fc1a}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-400{--tw-bg-opacity: 1;background-color:rgb(250 204 21 / var(--tw-bg-opacity, 1))}.bg-yellow-400\/10{background-color:#facc151a}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-amber-600{--tw-gradient-from: #d97706 var(--tw-gradient-from-position);--tw-gradient-to: rgb(217 119 6 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-400{--tw-gradient-from: #60a5fa var(--tw-gradient-from-position);--tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-400{--tw-gradient-from: #9ca3af var(--tw-gradient-from-position);--tw-gradient-to: rgb(156 163 175 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-50{--tw-gradient-from: #fdf2f8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-400{--tw-gradient-from: #c084fc var(--tw-gradient-from-position);--tw-gradient-to: rgb(192 132 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-amber-800{--tw-gradient-to: #92400e var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to: #2563eb var(--tw-gradient-to-position)}.to-gray-600{--tw-gradient-to: #4b5563 var(--tw-gradient-to-position)}.to-purple-50{--tw-gradient-to: #faf5ff var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.p-0{padding:0}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pr-6{padding-right:1.5rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tracking-wider{letter-spacing:.05em}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-gray-100{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-inner{--tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / .05);--tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-amber-600\/50{--tw-shadow-color: rgb(217 119 6 / .5);--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-400\/50{--tw-shadow-color: rgb(96 165 250 / .5);--tw-shadow: var(--tw-shadow-colored)}.shadow-gray-400\/50{--tw-shadow-color: rgb(156 163 175 / .5);--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-400\/50{--tw-shadow-color: rgb(192 132 252 / .5);--tw-shadow: var(--tw-shadow-colored)}.outline{outline-style:solid}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-blue-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.ring-yellow-400{--tw-ring-opacity: 1;--tw-ring-color: rgb(250 204 21 / var(--tw-ring-opacity, 1))}.ring-opacity-50{--tw-ring-opacity: .5}.drop-shadow-md{--tw-drop-shadow: drop-shadow(0 4px 3px rgb(0 0 0 / .07)) drop-shadow(0 2px 2px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-1000{transition-duration:1s}.duration-500{transition-duration:.5s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}*{margin:0;padding:0;box-sizing:border-box}.app-container *{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mode-container{position:absolute!important;width:100%!important;height:100%!important}.modern-mode.active{display:flex!important;opacity:1!important;visibility:visible!important}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text-size-multiplier: 1}html *{font-size:calc(1em * var(--text-size-multiplier))}html.reduce-motion *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}body{margin:0;font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;overflow-x:hidden}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000000d}::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#0000004d}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .3s ease-out}body.hide-ui .player-status,body.hide-ui .achievement-button,body.hide-ui .help-button,body.hide-ui .menu-button,body.hide-ui .vn-controls,body.hide-ui .dialogue-box{opacity:0;pointer-events:none;transition:opacity .3s ease}body.hide-ui .vn-background,body.hide-ui .vn-character{transform:scale(1.05);transition:transform .3s ease}.hover\:scale-105:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-110:hover{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:transform:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.hover\:shadow-xl:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}@media (min-width: 640px){.sm\:max-h-\[90vh\]{max-height:90vh}.sm\:max-w-4xl{max-width:56rem}.sm\:rounded-xl{border-radius:.75rem}.sm\:p-4{padding:1rem}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:p-8{padding:2rem}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
