.alchemy-book-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:600px;width:90vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #eee}.dialog-header h3{margin:0;font-size:1.5rem;font-weight:600;color:#333}.dialog-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:background-color .2s}.dialog-close-btn:hover{background-color:#f5f5f5}.dialog-tabs{display:flex;border-bottom:1px solid #eee}.tab-button{flex:1;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:.95rem;color:#666;transition:all .2s;border-bottom:3px solid transparent}.tab-button:hover{background-color:#f8f9fa}.tab-button.active{color:#007bff;border-bottom-color:#007bff;background-color:#f8f9ff}.dialog-content{flex:1;padding:24px;overflow-y:auto}.select-tab{min-height:200px}.loading{text-align:center;padding:40px;color:#666}.books-list{display:flex;flex-direction:column;gap:12px}.book-item{padding:16px;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s}.book-item:hover{border-color:#007bff;background-color:#f8f9ff;transform:translateY(-1px)}.book-name{font-weight:600;font-size:1.1rem;color:#333;margin-bottom:4px}.book-description{color:#666;font-size:.9rem;line-height:1.4}.no-books{text-align:center;padding:40px;color:#666}.upload-tab{min-height:200px;display:flex;flex-direction:column;gap:24px}.upload-section{display:flex;flex-direction:column;gap:16px}.upload-label{font-weight:500;color:#333;margin-bottom:8px}.file-input{padding:12px;border:2px dashed #ccc;border-radius:8px;cursor:pointer;transition:border-color .2s}.file-input:hover{border-color:#007bff}.selected-file{padding:12px;background-color:#e8f5e8;border:1px solid #c3e6c3;border-radius:6px;color:#2d5a2d;font-size:.9rem}.upload-actions{display:flex;justify-content:flex-end}.upload-button{padding:12px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background-color .2s}.upload-button:disabled{background-color:#ccc;cursor:not-allowed}.upload-button:not(:disabled):hover{background-color:#0056b3}.url-tab{min-height:200px;display:flex;flex-direction:column;gap:24px}.url-section{display:flex;flex-direction:column;gap:8px}.url-label{font-weight:500;color:#333}.url-input{padding:12px 16px;border:2px solid #e9ecef;border-radius:6px;font-size:.95rem;transition:border-color .2s}.url-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.url-actions{display:flex;justify-content:flex-end}.url-button{padding:12px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background-color .2s}.url-button:disabled{background-color:#ccc;cursor:not-allowed}.url-button:not(:disabled):hover{background-color:#0056b3}@media (max-width: 768px){.alchemy-book-dialog{width:95vw;max-height:90vh}.dialog-header{padding:16px 20px 12px}.dialog-header h3{font-size:1.3rem}.dialog-content{padding:20px}.tab-button{padding:10px 12px;font-size:.9rem}.book-item{padding:12px}.book-name{font-size:1rem}}.about-dialog{background:#fff;border-radius:16px;max-width:800px;width:90vw;max-height:85vh;overflow:hidden;box-shadow:0 20px 40px #0000004d;position:relative;display:flex;flex-direction:column;animation:slideInScale .3s ease-out}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(-30px)}to{opacity:1;transform:scale(1) translateY(0)}}.about-dialog .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px 20px;border-bottom:2px solid #e9ecef;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.about-dialog .dialog-header h2{margin:0;font-size:24px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.about-dialog .dialog-close-btn{background:#fff3;border:none;font-size:24px;color:#fff;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.about-dialog .dialog-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.about-dialog .dialog-content{flex:1;overflow-y:auto;padding:0}.about-content{padding:32px;line-height:1.7;color:#333;font-size:16px}.about-h1{color:#2c3e50;font-size:32px;font-weight:800;margin:0 0 24px;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-h2{color:#34495e;font-size:24px;font-weight:700;margin:32px 0 16px;display:flex;align-items:center;gap:12px}.about-h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}.about-h3{color:#2c3e50;font-size:20px;font-weight:600;margin:24px 0 12px}.about-paragraph{margin:16px 0;color:#444}.about-list,.about-ordered-list{margin:16px 0;padding-left:24px}.about-list li,.about-ordered-list li{margin:8px 0;color:#555}.about-list li strong,.about-ordered-list li strong,.about-paragraph strong{color:#2c3e50;font-weight:600}.about-hr{border:none;height:2px;background:linear-gradient(90deg,transparent,#ddd,transparent);margin:32px 0}.about-dialog .dialog-content::-webkit-scrollbar{width:8px}.about-dialog .dialog-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.about-dialog .dialog-content::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}.about-dialog .dialog-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46a3)}@media (max-width: 768px){.about-dialog{width:95vw;max-height:90vh;margin:5vh auto;border-radius:12px}.about-dialog .dialog-header{padding:16px 20px;border-radius:12px 12px 0 0}.about-dialog .dialog-header h2{font-size:20px}.about-dialog .dialog-close-btn{width:36px;height:36px;font-size:20px}.about-content{padding:20px;font-size:14px}.about-h1{font-size:24px;margin-bottom:16px}.about-h2{font-size:20px;margin:24px 0 12px}.about-h3{font-size:18px;margin:20px 0 8px}.about-list,.about-ordered-list{padding-left:20px}}@media (prefers-color-scheme: dark){.about-dialog{background:#2d3748;color:#e2e8f0}.about-dialog .dialog-header{border-bottom-color:#4a5568}.about-content{color:#e2e8f0}.about-h1{color:#f7fafc}.about-h2{color:#e2e8f0}.about-h3{color:#f7fafc}.about-paragraph{color:#cbd5e0}.about-list li,.about-ordered-list li{color:#a0aec0}.about-list li strong,.about-ordered-list li strong,.about-paragraph strong{color:#f7fafc}.about-hr{background:linear-gradient(90deg,transparent,#4a5568,transparent)}.about-dialog .dialog-content::-webkit-scrollbar-track{background:#4a5568}}.about-content p:last-child{text-align:center;font-size:18px;font-style:italic;margin-top:32px;padding:16px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:12px;border:2px dashed rgba(102,126,234,.3)}@media (prefers-color-scheme: dark){.about-content p:last-child{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea66}}.menu-area{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#fff;border-bottom:1px solid #e9ecef;color:#333;position:relative;z-index:100;box-shadow:0 2px 4px #0000001a}.header-left{display:flex;align-items:center;gap:16px}.logo-col{display:flex;align-items:center}.game-logo{width:48px;height:48px}.app-name-col{display:flex;align-items:center}.app-name{display:flex;flex-direction:column;line-height:1.1;font-size:1.5rem;font-weight:600;margin:0}.app-name span{display:block}.book-info-col{display:flex;flex-direction:column;gap:2px}.book-name{font-size:1rem;opacity:.8;font-style:italic}.change-book-link{background:none;border:none;color:#007bff;font-size:.85rem;text-decoration:underline;cursor:pointer;padding:2px 4px;border-radius:3px;transition:background-color .2s}.change-book-link:hover{background-color:#007bff1a;text-decoration:none}.menu-container{position:relative}.menu-toggle{background:#f8f9fa;border:1px solid #dee2e6;color:#333;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:1.2rem;transition:background .2s}.menu-toggle:hover{background:#e9ecef}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:8px 0;min-width:160px;box-shadow:0 4px 20px #00000026}.menu-dropdown button{display:block;width:100%;padding:12px 20px;background:none;border:none;color:#333;text-align:left;cursor:pointer;transition:background .2s;font-size:.9rem}.menu-dropdown button:hover{background:#f8f9fa}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:24px;border-radius:12px;min-width:320px;max-width:90vw;color:#333}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal h3{margin:0;color:#333}.modal-close-btn{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px;line-height:1;border-radius:3px;transition:all .2s}.modal-close-btn:hover{background:#f0f0f0;color:#333}.url-input{width:100%;padding:10px;border:2px solid #ddd;border-radius:6px;margin-bottom:16px;font-size:1rem}.setting-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.setting-row label{display:flex;align-items:center;gap:8px}.setting-row select{padding:6px 10px;border:2px solid #ddd;border-radius:4px}.modal-buttons{display:flex;gap:12px;justify-content:flex-end}.modal-buttons button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.modal-buttons button:first-child{background:#4caf50;color:#fff}.modal-buttons button:last-child{background:#f44336;color:#fff}.modal-buttons button:hover{opacity:.9}.voice-selector-container{display:flex;gap:8px;align-items:center}.voice-selector-container select{flex:1;padding:6px 10px;border:2px solid #ddd;border-radius:4px}.voice-selector-container select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed;opacity:.6}.test-voice-btn{padding:6px 12px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;white-space:nowrap;transition:background .2s}.test-voice-btn:hover:not(:disabled){background:#0056b3}.test-voice-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.menu-area{padding:10px 16px}.header-left{gap:12px}.app-name{font-size:1.2rem}.book-name{font-size:.9rem}.change-book-link{font-size:.8rem}.game-logo{width:40px;height:40px}}.artifact-formula-dialog{background:#fff;border-radius:12px;max-width:500px;width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;position:relative;animation:slideInScale .2s ease-out}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.artifact-formula-dialog .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px 12px 0 0}.artifact-display{display:flex;align-items:center;gap:12px}.artifact-icon{width:50px;height:50px;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;flex-shrink:0}.artifact-emoji{font-size:24px;font-family:"Noto Color Emoji",sans-serif}.artifact-name-icon{font-size:10px;font-weight:700;text-align:center;line-height:1.2;word-break:break-word;padding:2px}.artifact-title{margin:0;color:#212529;font-size:20px;font-weight:600}.artifact-formula-dialog .dialog-close-btn{background:none;border:none;font-size:20px;color:#6c757d;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.artifact-formula-dialog .dialog-close-btn:hover{background:#0000001a;color:#495057}.artifact-formula-dialog .dialog-content{padding:20px}.formula-section{margin-bottom:24px}.formula-title{margin:0 0 16px;color:#495057;font-size:16px;font-weight:600}.formula-display{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:16px;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.ingredients{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ingredient{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;box-shadow:0 2px 4px #0000001a;transition:transform .1s ease}.ingredient:hover{transform:translateY(-1px)}.ingredient.unknown{background:#6c757d;color:#fff;font-style:italic}.ingredient-emoji{font-size:14px;font-family:"Noto Color Emoji",sans-serif}.ingredient-name{font-weight:600}.formula-plus{font-size:16px;font-weight:700;color:#6c757d;margin:0 4px}.formula-arrow{font-size:20px;color:#28a745;font-weight:700;margin:0 8px}.result{display:flex;align-items:center}.result-artifact{font-weight:700;font-size:14px;transform:scale(1.1);border:2px solid rgba(255,255,255,.3)}.base-element{text-align:center;padding:24px;background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:8px;border:2px solid #e1bee7}.base-element-text{font-size:18px;font-weight:600;color:#4a148c;display:block;margin-bottom:8px}.base-element-description{color:#7b1fa2;font-size:14px;margin:0;font-style:italic}@media (max-width: 768px){.artifact-formula-dialog{width:95vw;max-height:90vh;margin:5vh auto}.artifact-formula-dialog .dialog-header{padding:16px}.artifact-title{font-size:18px}.artifact-icon{width:40px;height:40px}.artifact-emoji{font-size:20px;font-family:"Noto Color Emoji",sans-serif}.artifact-formula-dialog .dialog-content{padding:16px}.formula-display{flex-direction:column;align-items:stretch;gap:8px;padding:12px}.ingredients{justify-content:center}.formula-arrow{align-self:center;margin:4px 0}.result{justify-content:center}}@media (prefers-color-scheme: dark){.artifact-formula-dialog{background:#2b2b2b;color:#e9ecef}.artifact-formula-dialog .dialog-header{background:linear-gradient(135deg,#3c3c3c,#2b2b2b);border-bottom-color:#495057}.artifact-title{color:#e9ecef}.formula-title{color:#ced4da}.formula-display{background:#343a40;border-color:#495057}.formula-plus,.formula-arrow{color:#ced4da}.base-element{background:linear-gradient(135deg,#2c3e50,#34495e);border-color:#5a6c7d}.base-element-text{color:#a8c8ec}.base-element-description{color:#74a9d8}}.artifacts-area{width:280px;min-width:280px;background:#fff;border-right:1px solid #e9ecef;border-radius:8px 0 0 8px;margin:8px 0 8px 8px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 4px #0000001a}.no-book-message{display:flex;align-items:center;justify-content:center;height:100%;color:#6c757d;text-align:center;padding:20px;font-style:italic}.stats{padding:16px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.stat{display:flex;justify-content:space-between;margin-bottom:8px;color:#333}.stat:last-child{margin-bottom:0}.stat-label{font-size:.9rem;opacity:.8}.stat-value{font-weight:600;font-size:1rem;color:#4caf50}.artifacts-canvas-container{flex:1;overflow:auto;position:relative}.artifacts-canvas{width:100%;height:100%;min-height:400px;cursor:pointer;touch-action:none}.artifacts-canvas:active{cursor:grabbing}@media (max-width: 768px){.artifacts-area{width:100%;min-width:100%;height:200px;border-right:none;border-bottom:1px solid #e9ecef}.stats{padding:12px;display:flex;gap:20px}.stat{margin-bottom:0;flex-direction:column;gap:4px}.artifacts-canvas{min-height:120px;height:auto;touch-action:pan-y pinch-zoom}.artifacts-canvas-container{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:auto;scrollbar-color:rgba(0,0,0,.4) rgba(0,0,0,.1);overflow-y:scroll}.artifacts-canvas-container::-webkit-scrollbar{width:12px;background:#0000000d}.artifacts-canvas-container::-webkit-scrollbar-track{background:#0000000d;border-radius:6px}.artifacts-canvas-container::-webkit-scrollbar-thumb{background:#00000080;border-radius:6px;border:2px solid rgba(255,255,255,.2);min-height:30px}.artifacts-canvas-container::-webkit-scrollbar-thumb:hover{background:#000000b3}.artifacts-canvas-container::-webkit-scrollbar-thumb:active{background:#000000e6}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: landscape){.artifacts-area{width:240px;min-width:240px}.artifacts-canvas{height:auto}.artifacts-canvas-container{overflow-y:auto}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: portrait){.artifacts-area{width:100%;min-width:100%;height:200px;border-right:none;border-bottom:1px solid #e9ecef}.stats{padding:12px;display:flex;gap:20px}.stat{margin-bottom:0;flex-direction:column;gap:4px}.artifacts-canvas{min-height:120px;height:auto;touch-action:pan-y pinch-zoom}.artifacts-canvas-container{overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:auto;scrollbar-color:rgba(0,0,0,.4) rgba(0,0,0,.1);overflow-y:scroll}.artifacts-canvas-container::-webkit-scrollbar{width:12px;background:#0000000d}.artifacts-canvas-container::-webkit-scrollbar-track{background:#0000000d;border-radius:6px}.artifacts-canvas-container::-webkit-scrollbar-thumb{background:#00000080;border-radius:6px;border:2px solid rgba(255,255,255,.2);min-height:30px}}.main-area{flex:1;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:8px;position:relative;overflow:hidden;box-shadow:0 2px 4px #0000001a}.main-canvas{width:100%;height:100%;cursor:grab;touch-action:manipulation;-webkit-user-select:none;user-select:none}.main-canvas:active{cursor:grabbing}.main-canvas{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}@media (max-width: 768px){.main-area{flex:1;min-height:0}.main-canvas{width:100%;height:100%}}@media (min-width: 769px){.main-area{flex:1;min-width:0}}@font-face{font-family:"Noto Color Emoji";src:url(../fonts/NotoColorEmoji-Regular.ttf) format("truetype");font-display:swap}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;overflow:hidden;height:100vh;color:#333}.app{height:100vh;display:flex;flex-direction:column;position:relative}.app.loading{justify-content:center;align-items:center}.loading-message{color:#333;font-size:1.5rem;text-align:center}.game-area{flex:1;display:flex;overflow:hidden}.error-message{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#ff0000e6;color:#fff;padding:12px 24px;border-radius:8px;z-index:1000}@media (max-width: 768px){.game-area{flex-direction:column}}@media (min-width: 769px){.game-area{flex-direction:row}}
