body{font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(to right,#ece9e6,#fff);margin:0;padding:20px;box-sizing:border-box;color:#333}#root{width:100%;max-width:700px;margin:0 auto}.container{background-color:#fff;padding:30px 40px;border-radius:12px;box-shadow:0 10px 30px #0000001a;width:100%;box-sizing:border-box}h1{text-align:center;color:#2c3e50;margin-bottom:30px;font-size:2.2em;font-weight:700}.input-group{margin-bottom:20px}.input-group label{display:block;margin-bottom:8px;color:#34495e;font-weight:600;font-size:1.05em}.input-group input[type=password],.input-group input[type=url],.input-group input[type=number],.input-group input[type=text],.input-group select{width:100%;padding:12px 15px;border:1px solid #c0d9e6;border-radius:8px;box-sizing:border-box;font-size:1em;color:#333;background-color:#f8faff;transition:all .3s ease}.input-group input:focus,.input-group select:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px #007bff33;background-color:#fff}.input-help{display:block;margin-top:5px;font-size:.85em;color:#6c757d;font-style:italic}.button-group{display:flex;flex-direction:column;gap:15px;margin-top:30px}.button-group button{background-color:#007bff;color:#fff;padding:14px 28px;border:none;border-radius:8px;font-size:1.1em;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .2s ease;width:100%}.button-group button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px)}.button-group button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.8}.clear-data-section{margin-top:20px;padding-top:15px;border-top:1px solid #e9ecef;text-align:center}.clear-data-button{background-color:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.9em;font-weight:600;transition:background-color .3s ease;display:inline-flex;align-items:center;gap:8px}.clear-data-button:hover:not(:disabled){background-color:#c82333}.clear-data-button:disabled{background-color:#6c757d;cursor:not-allowed}.status{margin-top:25px;padding:12px 15px;border-radius:8px;background-color:#e6f7ff;color:#0056b3;text-align:center;font-size:1em;border:1px solid #b3e0ff;transition:opacity .3s ease;min-height:40px;display:flex;align-items:center;justify-content:center}.progress-bar-container{width:100%;background-color:#e0e0e0;border-radius:5px;margin-top:15px;overflow:hidden}.progress-bar{height:25px;background-color:#28a745;border-radius:5px;text-align:center;color:#fff;line-height:25px;font-size:.9em;transition:width .5s ease-in-out}.preview-text-container{margin-top:30px;border:1px solid #d1ecf1;border-radius:8px;background-color:#f8f9fa;padding:20px}.preview-text-container h2{color:#2c3e50;margin-bottom:20px;font-size:1.5em}.chapter-selector{margin-bottom:20px}.chapter-selector label{display:block;margin-bottom:8px;color:#34495e;font-weight:600;font-size:1.05em}.chapter-selector select{width:100%;padding:12px 15px;border:1px solid #c0d9e6;border-radius:8px;box-sizing:border-box;font-size:1em;color:#333;background-color:#fff;transition:all .3s ease}.chapter-selector select:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px #007bff33}.chapter-content{margin-top:20px}.chapter-content h3{color:#2c3e50;margin-bottom:15px;font-size:1.3em;border-bottom:2px solid #007bff;padding-bottom:5px}.chapter-text{background-color:#fff;border:1px solid #dee2e6;border-radius:6px;padding:20px;font-family:Georgia,Times New Roman,serif;font-size:1.05em;line-height:1.6;color:#2c3e50;white-space:pre-wrap;word-wrap:break-word;max-height:600px;overflow-y:auto;box-shadow:inset 0 1px 3px #0000001a}.fallback-input-container{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:20px;margin:20px 0}.fallback-input-container h3{color:#856404;margin-top:0;margin-bottom:10px}.fallback-input-container p{color:#856404;margin-bottom:15px}.fallback-textarea{width:100%;min-height:200px;padding:12px;border:1px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:14px;resize:vertical;box-sizing:border-box}.fallback-buttons{display:flex;gap:10px;margin-top:15px}.fallback-buttons button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s ease}.fallback-buttons button:first-child{background-color:#28a745;color:#fff}.fallback-buttons button:first-child:hover:not(:disabled){background-color:#218838}.fallback-buttons button:first-child:disabled{background-color:#6c757d;cursor:not-allowed}.fallback-type-selector{margin-bottom:15px;display:flex;flex-direction:column;gap:8px}.fallback-type-selector label{display:flex;align-items:center;gap:8px;color:#856404;cursor:pointer;font-weight:600}.fallback-type-selector input[type=radio]{margin:0}.cancel-button{background-color:#6c757d!important;color:#fff!important}.cancel-button:hover{background-color:#5a6268!important}.retry-button{background-color:#ffc107!important;color:#212529!important}.retry-button:hover{background-color:#e0a800!important}.chapter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.edit-button{background-color:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s ease}.edit-button:hover:not(:disabled){background-color:#0056b3}.edit-button:disabled{background-color:#6c757d;cursor:not-allowed}.edit-container{margin-top:15px}.edit-textarea{width:100%;min-height:400px;padding:15px;border:1px solid #ddd;border-radius:6px;font-family:Georgia,Times New Roman,serif;font-size:1.05em;line-height:1.6;resize:vertical;box-sizing:border-box}.edit-buttons{display:flex;gap:10px;margin-top:15px}.save-button{background-color:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .3s ease}.save-button:hover{background-color:#218838}.table-of-contents{margin-bottom:30px;background-color:#f8f9fa;border-radius:8px;padding:20px}.table-of-contents h3{margin-top:0;margin-bottom:15px;color:#2c3e50}.chapter-list{display:flex;flex-direction:column;gap:10px}.chapter-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 1px 3px #0000001a}.chapter-info{display:flex;flex-direction:column;gap:4px}.chapter-title{font-weight:600;color:#2c3e50;font-size:1.05em}.chapter-length{font-size:.9em;color:#6c757d}.chapter-actions{display:flex;gap:8px}.view-button{background-color:#17a2b8;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9em;font-weight:600;transition:background-color .3s ease}.view-button:hover{background-color:#138496}.delete-button{background-color:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9em;font-weight:600;transition:background-color .3s ease}.delete-button:hover{background-color:#c82333}@media (min-width: 768px){.button-group{flex-direction:row;justify-content:space-between}.button-group button{width:auto;min-width:200px}.chapter-text{max-height:800px}.fallback-buttons,.edit-buttons{flex-direction:row}}@media (max-width: 767px){.chapter-header{flex-direction:column;align-items:stretch;gap:10px}.fallback-buttons,.edit-buttons{flex-direction:column}.chapter-item{flex-direction:column;align-items:stretch;gap:10px}.chapter-actions{justify-content:center}}.glossary-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.glossary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.glossary-header h2{margin:0;color:#333;font-size:1.5rem}.generate-glossary-button{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.generate-glossary-button:hover:not(:disabled){background:#218838;transform:translateY(-2px)}.generate-glossary-button:disabled{background:#6c757d;cursor:not-allowed;transform:none}.glossary-info{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.glossary-info p{margin:0;color:#666;font-size:.9rem}.characters-section{margin-top:1rem}.characters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.characters-header h3{margin:0;color:#333}.add-character-button{background:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.add-character-button:hover{background:#0056b3;transform:translateY(-1px)}.characters-list{display:flex;flex-direction:column;gap:1rem}.character-item{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;background:#fafafa}.character-display .character-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;flex-wrap:wrap;gap:1rem}.character-names h4{margin:0;color:#333;font-size:1.1rem}.japanese-name{color:#666;font-size:.9rem;font-weight:400;margin-left:.5rem}.character-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.importance-badge{color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.age-badge{background:#6c757d;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem}.occurrence-badge{background:#17a2b8;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:700}.stop-button{background:#fd7e14!important;color:#fff!important;border:none!important;padding:12px 24px!important;border-radius:8px!important;font-size:1.1em!important;font-weight:600!important;cursor:pointer!important;transition:all .3s ease!important;display:flex!important;align-items:center!important;gap:8px!important}.stop-button:hover{background:#e8590c!important;transform:translateY(-2px)!important;box-shadow:0 8px 25px #fd7e144d!important}.physical-appearance{margin:.5rem 0;color:#555;font-size:.9rem;font-style:italic}.character-description{margin:.5rem 0;color:#333;line-height:1.4}.character-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.edit-character-button{background:#ffc107;color:#212529;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.edit-character-button:hover{background:#e0a800;transform:translateY(-1px)}.delete-character-button{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.delete-character-button:hover{background:#c82333;transform:translateY(-1px)}.character-form{display:flex;flex-direction:column;gap:1rem}.add-character-form{border:2px dashed #007bff;border-radius:8px;padding:1.5rem;margin-bottom:1rem;background:#f8f9ff}.add-character-form h4{margin:0 0 1rem;color:#007bff}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:.75rem}.character-form input,.character-form select,.character-form textarea{padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:border-color .3s ease}.character-form input:focus,.character-form select:focus,.character-form textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.form-buttons{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}.save-button{background:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.save-button:hover{background:#218838;transform:translateY(-1px)}.cancel-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.cancel-button:hover{background:#5a6268;transform:translateY(-1px)}.no-glossary{text-align:center;padding:2rem;color:#666;font-style:italic}
