.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-box{background:#fff;padding:48px;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:480px;width:100%}.auth-box h2{font-size:32px;margin-bottom:8px;color:#333;text-align:center}.auth-subtitle{font-size:16px;color:#666;text-align:center;margin-bottom:32px}.auth-box form{display:flex;flex-direction:column;gap:16px}.auth-box input[type=text],.auth-box input[type=email],.auth-box input[type=password]{padding:16px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .3s}.auth-box input:focus{outline:none;border-color:#667eea}.profile-type{display:flex;gap:20px;padding:12px 0}.profile-type label{display:flex;align-items:center;gap:8px;font-size:16px;cursor:pointer}.profile-type input[type=radio]{width:20px;height:20px;cursor:pointer}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px}.auth-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:18px;padding:16px;border:none;border-radius:8px;cursor:pointer;margin-top:8px}.auth-toggle{text-align:center;margin-top:24px;color:#666}.auth-toggle button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0}@media (max-width: 768px){.auth-container{padding:16px;min-height:100vh}.auth-box{padding:24px;max-width:100%;width:100%}.auth-box h2{font-size:24px}.auth-subtitle{font-size:14px;margin-bottom:24px}.auth-box input[type=text],.auth-box input[type=email],.auth-box input[type=password]{padding:14px;font-size:16px}.profile-type{flex-direction:column;gap:12px}.auth-btn{font-size:16px;padding:14px}.verification-input{font-size:24px!important;letter-spacing:8px;padding:16px 12px!important}.resend-btn{font-size:14px;padding:10px 20px}}.recaptcha-notice{margin-top:20px;font-size:12px;color:#666;text-align:center}.recaptcha-notice a{color:#667eea;text-decoration:none}.recaptcha-notice a:hover{text-decoration:underline}.forgot-password-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;margin-top:10px;text-decoration:underline}.forgot-password-link:hover{color:#5568d3}.verification-input{font-size:32px!important;letter-spacing:10px;text-align:center;font-weight:700}.resend-btn{background:none;border:1px solid #667eea;color:#667eea;padding:12px 24px;border-radius:8px;font-size:16px;cursor:pointer;transition:all .3s ease;margin-top:10px}.resend-btn:hover:not(:disabled){background:#f3f4f6}.resend-btn:disabled{opacity:.5;cursor:not-allowed}.success-message{background:#d1fae5;color:#065f46;padding:12px;border-radius:6px;margin:10px 0;font-size:14px}.photo-upload{display:flex;flex-direction:column;gap:40px}.upload-zone{border:3px dashed #ccc;border-radius:12px;padding:60px;text-align:center;transition:all .3s ease;background:#fafafa}.upload-zone.drag-active{border-color:#667eea;background:#f0f4ff}.upload-label{cursor:pointer;display:block}.upload-icon{font-size:80px;margin-bottom:20px}.upload-zone h3{font-size:24px;margin-bottom:10px;color:#333}.upload-zone p{font-size:18px;color:#666}.uploading{display:flex;flex-direction:column;align-items:center;gap:20px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.photo-grid h3{font-size:24px;margin-bottom:20px;color:#333}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.photo-card{position:relative;cursor:pointer;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.photo-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.photo-delete-btn{position:absolute;top:8px;right:8px;background:#ffffffe6;border:none;border-radius:50%;width:36px;height:36px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s ease;z-index:10}.photo-card:hover .photo-delete-btn{opacity:1}.photo-delete-btn:hover{background:#fee;transform:scale(1.1)}.photo-card img{width:100%;height:200px;object-fit:cover}.photo-card p{padding:12px;font-size:14px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-recorder{margin:20px 0;padding:20px;background:#f9f9f9;border-radius:12px}.recorder-controls{display:flex;justify-content:center}.record-btn,.stop-btn{font-size:18px;padding:16px 32px;border-radius:8px;border:none;cursor:pointer}.record-btn{background:#4caf50;color:#fff}.stop-btn{background:#f44336;color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.audio-preview{margin-top:20px;text-align:center}.audio-preview p{color:#4caf50;font-weight:600;margin-bottom:12px}.audio-preview audio{width:100%;max-width:400px}.recording-active{display:flex;flex-direction:column;align-items:center;gap:12px}.recording-indicator{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#f44336}.recording-dot{width:12px;height:12px;background:#f44336;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.recording-time{font-family:monospace;font-size:18px}.story-media-manager{margin:20px 0;padding:15px;background:#f8f9fa;border-radius:8px}.media-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.media-header h4{margin:0;color:#333;font-size:16px}.add-media-btn{padding:8px 16px;background:#7c3aed;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.add-media-btn:hover{background:#6d28d9}.add-media-btn:disabled{background:#ccc;cursor:not-allowed}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:15px}.media-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.media-item img{width:100%;height:100%;object-fit:cover}.remove-media-btn{position:absolute;top:5px;right:5px;width:24px;height:24px;background:#dc2626e6;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s}.remove-media-btn:hover{background:#b91c1c}.remove-media-btn:disabled{background:#9ca3afe6;cursor:not-allowed}.add-media-panel{margin-top:15px;padding:15px;background:#fff;border-radius:8px;border:2px dashed #d1d5db}.add-media-options{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.upload-new-photo-btn{display:block;padding:12px 20px;background:#10b981;color:#fff;border-radius:8px;text-align:center;cursor:pointer;font-weight:500;transition:background .2s}.upload-new-photo-btn:hover{background:#059669}.option-divider{text-align:center;color:#9ca3af;font-size:14px;font-weight:500;margin:5px 0}.select-existing-label{color:#6b7280;font-size:14px;font-weight:500;margin-bottom:5px}.add-media-panel h5{margin:0 0 15px;color:#333;font-size:14px}.no-photos{text-align:center;color:#6b7280;padding:20px;font-style:italic}.photo-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;max-height:300px;overflow-y:auto}.photo-selector-item{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer;transition:transform .2s}.photo-selector-item:hover{transform:scale(1.05)}.photo-selector-item img{width:100%;height:100%;object-fit:cover}.photo-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#7c3aedcc;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.photo-selector-item:hover .photo-overlay{opacity:1}.photo-overlay span{color:#fff;font-weight:700;font-size:14px}@media (max-width: 768px){.media-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.photo-selector-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.media-header{flex-direction:column;align-items:flex-start;gap:10px}.add-media-btn{width:100%}}.story-editor{width:100%}.editor-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px}.photo-preview{position:sticky;top:20px;height:fit-content}.photo-preview img{width:100%;border-radius:12px;box-shadow:0 8px 24px #00000026}.photo-name{margin-top:16px;font-size:16px;color:#666;text-align:center}.editor-panel{display:flex;flex-direction:column}.generate-prompt{text-align:center;padding:60px 40px;background:#f9f9f9;border-radius:12px}.generate-prompt h3{font-size:28px;margin-bottom:16px;color:#333}.generate-prompt p{font-size:18px;color:#666;margin-bottom:32px;line-height:1.6}.story-textarea{width:100%;min-height:200px;padding:16px;font-size:16px;line-height:1.6;border:2px solid #e0e0e0;border-radius:8px;resize:vertical;font-family:Georgia,serif;margin-bottom:20px}.initial-actions{display:flex;gap:12px;justify-content:center}.generate-btn,.create-btn{font-size:16px;padding:14px 32px;border-radius:8px;cursor:pointer;border:none;transition:transform .2s,opacity .2s}.generate-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.generate-btn:hover:not(:disabled){transform:translateY(-2px)}.create-btn{background:#4caf50;color:#fff}.create-btn:hover:not(:disabled){transform:translateY(-2px)}.generate-btn:disabled,.create-btn:disabled{opacity:.5;cursor:not-allowed}.voice-only-hint{margin-top:16px;font-size:14px;color:#666;font-style:italic}.editor-content{display:flex;flex-direction:column;gap:20px}.editor-header{display:flex;align-items:center;gap:12px}.editor-header h3{font-size:24px;color:#333}.edited-badge{background:#4caf50;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.editor-content .story-textarea{width:100%;min-height:400px;padding:20px;font-size:18px;line-height:1.8;border:2px solid #e0e0e0;border-radius:12px;resize:vertical;font-family:Georgia,serif}.editor-content .story-textarea:focus{outline:none;border-color:#667eea}.editor-actions{display:flex;gap:12px}.save-btn{flex:1;background:#4caf50!important;color:#fff!important;font-size:18px;padding:16px;cursor:pointer!important;border:none;border-radius:8px;transition:background .2s;opacity:1!important;pointer-events:auto!important}.save-btn:hover{background:#45a049!important}.save-btn:active{transform:scale(.98)}.save-btn:disabled{background:#4caf50!important;opacity:1!important;cursor:pointer!important}.regenerate-btn{background:#f5f5f5;color:#666;font-size:18px;padding:16px 24px}.audio-attached-indicator{background:#e8f5e9;border:2px solid #4caf50;border-radius:8px;padding:16px;text-align:center;color:#2e7d32;font-size:16px;font-weight:600}@media (max-width: 768px){.editor-layout{grid-template-columns:1fr}.photo-preview{position:relative}}.story-title-input{width:100%;padding:12px 16px;font-size:18px;font-weight:600;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:12px;transition:border-color .3s}.chapter-select{width:100%;padding:12px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;margin-bottom:16px;transition:border-color .3s}.freeform-story{max-width:900px;margin:0 auto}.story-header{text-align:center;margin-bottom:32px}.story-header h2{font-size:36px;color:#333;margin-bottom:12px}.story-header p{font-size:18px;color:#666}.story-modes{display:flex;gap:12px;justify-content:center;margin-bottom:32px}.mode-btn{padding:16px 32px;font-size:18px;border:2px solid #e0e0e0;background:#fff;border-radius:12px;cursor:pointer;transition:all .3s}.mode-btn:hover{border-color:#667eea;transform:translateY(-2px)}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.story-form{background:#f9f9f9;padding:32px;border-radius:16px}.story-title-input{width:100%;padding:16px;font-size:24px;border:2px solid #e0e0e0;border-radius:12px;margin-bottom:24px;font-weight:600}.story-title-input:focus{outline:none;border-color:#667eea}.story-layout{display:grid;grid-template-columns:1fr 320px;gap:24px}.story-main{display:flex;flex-direction:column}.story-sidebar{display:flex;flex-direction:column;gap:16px}.story-textarea{width:100%;min-height:400px;padding:20px;font-size:18px;line-height:1.8;border:2px solid #e0e0e0;border-radius:12px;resize:vertical;font-family:Georgia,serif;margin-bottom:24px}.story-textarea:focus{outline:none;border-color:#667eea}.voice-mode,.ai-mode{margin-bottom:24px}.voice-instructions,.ai-instructions{background:#fff;padding:20px;border-radius:12px;margin-bottom:20px;text-align:center}.voice-instructions p,.ai-instructions p{color:#666;font-size:16px;margin-bottom:8px}.ai-generate-btn{background:#667eea;color:#fff;padding:12px 24px;font-size:16px;border-radius:8px;border:none;cursor:pointer;margin-top:12px}.ai-generate-btn:disabled{opacity:.5;cursor:not-allowed}.photo-optional{background:#fff;padding:20px;border-radius:12px}.photo-optional h3{font-size:18px;color:#333;margin-bottom:6px}.photo-optional p{color:#666;font-size:13px;margin-bottom:12px}.photo-select-btn{display:block;width:100%;padding:12px;background:#f5f5f5;border:2px dashed #ccc;border-radius:8px;cursor:pointer;font-size:14px;text-align:center;transition:all .3s}.photo-select-btn:hover{border-color:#667eea;background:#f0f4ff}.remove-photo-btn{width:100%;margin-top:8px;padding:10px;background:#fee;color:#c33;border:none;border-radius:8px;cursor:pointer;font-size:13px}.chapter-selection{background:#fff;padding:20px;border-radius:12px}.chapter-selection h3{font-size:18px;color:#333;margin-bottom:6px}.chapter-selection p{color:#666;font-size:13px;margin-bottom:12px}.chapter-select{width:100%;padding:12px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:border-color .3s}.chapter-select:focus{outline:none;border-color:#667eea}.no-chapters-hint{margin-top:12px;padding:12px;background:#fff9e6;border-left:4px solid #ffc107;border-radius:4px;color:#666;font-size:14px}.story-actions{display:flex;gap:12px}.save-story-btn{flex:1;padding:18px;font-size:20px;background:#4caf50;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s}.save-story-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.save-story-btn:disabled{opacity:.5;cursor:not-allowed}.clear-btn{padding:18px 32px;font-size:18px;background:#f5f5f5;color:#666;border:none;border-radius:12px;cursor:pointer}.story-tips{margin-top:32px;padding:24px;background:#fff9e6;border-radius:12px;border-left:4px solid #ffc107}.story-tips h3{font-size:20px;color:#333;margin-bottom:16px}.story-tips ul{list-style:none;padding:0}.story-tips li{color:#666;font-size:16px;padding:8px 0 8px 24px;position:relative}.story-tips li:before{content:"✓";position:absolute;left:0;color:#ffc107;font-weight:700}.audio-recorded-indicator{background:#e8f5e9;border:2px solid #4caf50;border-radius:8px;padding:16px;margin:16px 0;text-align:center;color:#2e7d32;font-size:16px;font-weight:600}@media (max-width: 768px){.story-layout{grid-template-columns:1fr}.story-sidebar{order:-1;display:grid;grid-template-columns:1fr 1fr;gap:12px}.freeform-story{padding:0 16px}.story-header h2{font-size:24px}.story-header p{font-size:14px}.story-modes{display:flex;flex-direction:row;gap:8px;justify-content:space-between}.mode-btn{flex:1;padding:12px 8px;font-size:14px;white-space:nowrap}.story-form{padding:16px}.story-title-input{font-size:18px;padding:12px}.story-textarea{min-height:300px;font-size:16px;padding:16px}.save-story-btn{font-size:16px;padding:14px}.clear-btn{font-size:14px;padding:14px 20px}.photo-optional,.chapter-selection{padding:16px}.photo-optional h3,.chapter-selection h3{font-size:16px}.photo-optional p,.chapter-selection p{font-size:12px}}.selected-photos-list{margin-top:12px;padding:12px;background:#f9f9f9;border-radius:8px;max-height:200px;overflow-y:auto}.selected-photo-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#fff;border-radius:6px;margin-bottom:6px;font-size:13px}.selected-photo-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.remove-photo-btn-small{background:#fee;color:#c33;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px;font-weight:700}.remove-photo-btn-small:hover{background:#fcc}.timeline{width:100%}.timeline-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.timeline h2{font-size:32px;margin-bottom:8px;color:#333}.timeline-subtitle{font-size:16px;color:#666;margin-bottom:0}.refresh-btn{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.refresh-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-btn:disabled{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.timeline-list{display:flex;flex-direction:column;gap:24px}.timeline-item{display:flex;gap:24px;padding:20px;background:#f9f9f9;border-radius:12px;cursor:pointer;transition:all .3s ease;border-left:4px solid #667eea;position:relative}.timeline-delete-btn{position:absolute;top:12px;right:12px;background:#ffffffe6;border:1px solid #ddd;border-radius:6px;padding:6px 10px;font-size:16px;cursor:pointer;opacity:0;transition:all .2s;z-index:10}.timeline-item:hover .timeline-delete-btn{opacity:1}.timeline-delete-btn:hover{background:#fee;border-color:#c33;transform:scale(1.1)}.timeline-item.story{border-left-color:#4caf50;cursor:pointer}.timeline-item:hover{background:#f0f0f0;transform:translate(8px)}.timeline-item.story:hover{transform:translate(4px)}.timeline-photo{flex-shrink:0;width:150px;height:150px;border-radius:8px;overflow:hidden}.timeline-photo img{width:100%;height:100%;object-fit:cover}.timeline-content{flex:1;display:flex;flex-direction:column;gap:12px}.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.timeline-content h3{font-size:20px;color:#333;flex:1}.timeline-date{font-size:14px;color:#999;white-space:nowrap}.story-preview{font-size:16px;line-height:1.6;color:#666}.no-story{font-size:16px;color:#999;font-style:italic}.has-audio{display:inline-block;background:#e8f5e9;color:#4caf50;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:500;margin-bottom:8px}.timeline-audio{display:flex;flex-direction:column;gap:8px}.timeline-audio audio{width:100%;max-width:400px;height:40px}.story-badge{display:inline-block;background:#e3f2fd;color:#2196f3;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:500;margin-left:8px}.timeline-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;position:relative}.timeline-attached-photo{width:100%;height:120px;object-fit:cover;border-radius:8px}.more-photos{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}@media (max-width: 768px){.timeline-photos-grid{grid-template-columns:repeat(2,1fr)}.timeline-attached-photo{height:100px}}.chapters-sidebar{width:280px;background:#f8f9fa;border-right:2px solid #e0e0e0;display:flex;flex-direction:column;height:100%;overflow-y:auto}.chapters-header{padding:20px;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#fff;position:sticky;top:0;z-index:10}.chapters-header h3{margin:0;font-size:18px;color:#333}.add-chapter-btn{background:#4caf50;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s}.add-chapter-btn:hover{background:#45a049;transform:scale(1.1)}.chapter-form{padding:15px 20px;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;gap:10px}.chapter-form input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.chapter-form button{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.chapter-form button:hover{background:#45a049}.chapters-list{flex:1;overflow-y:auto}.chapter-item.all-stories{padding:15px 20px;background:#fff;border:none;border-bottom:1px solid #e0e0e0;width:100%;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:all .2s;display:flex;align-items:center;gap:8px}.chapter-item.all-stories:hover{background:#f0f0f0}.chapter-item.all-stories.active{background:#e3f2fd;color:#1976d2;font-weight:600}.chapter-group{border-bottom:1px solid #e0e0e0}.chapter-item{background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0;border:none;width:100%;transition:all .2s}.chapter-item.active{background:#e3f2fd}.chapter-actions{display:flex;align-items:center;gap:4px}.chapter-toggle{flex:1;padding:12px 20px;background:none;border:none;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#333;text-align:left}.chapter-toggle:hover{background:#f0f0f0}.chapter-icon{font-size:16px}.chapter-name{flex:1;font-weight:500}.page-count{font-size:12px;color:#666;background:#e0e0e0;padding:2px 8px;border-radius:10px}.add-page-btn{padding:8px 12px;background:none;border:none;color:#4caf50;font-size:18px;cursor:pointer;transition:all .2s}.add-page-btn:hover{background:#f0f0f0;transform:scale(1.2)}.delete-chapter-btn{padding:8px 12px;background:none;border:none;color:#f44336;font-size:16px;cursor:pointer;transition:all .2s;opacity:.6}.delete-chapter-btn:hover{background:#ffebee;opacity:1;transform:scale(1.2)}.pages-list{background:#fafafa;padding:5px 0}.no-pages{padding:12px 20px 12px 50px;font-size:13px;color:#999;font-style:italic}.page-item-wrapper{display:flex;align-items:center;position:relative}.page-item-wrapper:hover .delete-page-btn{opacity:1}.page-item{flex:1;padding:10px 20px 10px 50px;background:none;border:none;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#555;text-align:left;transition:all .2s}.page-item:hover{background:#e8e8e8}.delete-page-btn{padding:8px 12px;background:none;border:none;color:#f44336;font-size:14px;cursor:pointer;transition:all .2s;opacity:0}.delete-page-btn:hover{background:#ffebee;opacity:1;transform:scale(1.2)}.page-icon{font-size:14px}.page-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapters-sidebar::-webkit-scrollbar,.chapters-list::-webkit-scrollbar{width:6px}.chapters-sidebar::-webkit-scrollbar-track,.chapters-list::-webkit-scrollbar-track{background:#f1f1f1}.chapters-sidebar::-webkit-scrollbar-thumb,.chapters-list::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.chapters-sidebar::-webkit-scrollbar-thumb:hover,.chapters-list::-webkit-scrollbar-thumb:hover{background:#555}.chapters-mobile-toggle{display:none;position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:#667eea;color:#fff;border:none;font-size:24px;box-shadow:0 4px 12px #0000004d;cursor:pointer;z-index:1000;transition:all .3s}.chapters-mobile-toggle:active{transform:scale(.95)}.chapters-mobile-overlay{display:none}@media (max-width: 768px){.chapters-sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;z-index:999;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 8px #0000001a}.chapters-sidebar.mobile-open{transform:translate(0)}.chapters-mobile-toggle{display:flex;align-items:center;justify-content:center}.chapters-mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998}.chapters-mobile-overlay.active{display:block}}.family-sharing{background:#f9f9f9;padding:24px;border-radius:12px;margin-top:24px}.sharing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sharing-header h3{font-size:24px;color:#333}.add-family-btn{background:#667eea;color:#fff;padding:10px 20px;font-size:14px}.family-form{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;padding:20px;background:#fff;border-radius:8px}.family-form input{padding:12px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px}.family-form button{background:#4caf50;color:#fff;padding:12px;font-size:16px}.family-list{display:flex;flex-direction:column;gap:12px}.empty-state{text-align:center;color:#999;padding:20px;font-style:italic}.family-member{background:#fff;padding:16px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;border-left:4px solid #667eea}.member-info{display:flex;flex-direction:column;gap:4px}.member-info strong{font-size:16px;color:#333}.member-info span{font-size:14px;color:#666}.member-email{color:#999;font-size:14px}.video-export{max-width:900px;margin:0 auto}.video-header{text-align:center;margin-bottom:40px}.video-header h2{font-size:36px;color:#333;margin-bottom:12px}.video-header p{font-size:18px;color:#666}.video-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:40px}.feature{background:#f9f9f9;padding:24px;border-radius:12px;text-align:center}.feature .icon{font-size:48px;display:block;margin-bottom:12px}.feature h3{font-size:18px;color:#333;margin-bottom:8px}.feature p{font-size:14px;color:#666}.video-actions{text-align:center;margin:40px 0}.generate-video-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:20px;padding:20px 48px;border-radius:12px;border:none;cursor:pointer;transition:transform .3s}.generate-video-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.note{margin-top:16px;color:#999;font-size:14px}.video-progress{text-align:center;padding:40px;background:#f9f9f9;border-radius:12px}.progress-bar{width:100%;height:40px;background:#e0e0e0;border-radius:20px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .5s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.video-progress p{font-size:18px;color:#333;margin-bottom:8px}.progress-status{color:#667eea!important;font-weight:500}.video-result{text-align:center;padding:40px;background:#f9f9f9;border-radius:12px}.video-result h3{font-size:28px;color:#4caf50;margin-bottom:24px}.video-preview{width:100%;max-width:800px;border-radius:12px;margin-bottom:24px;box-shadow:0 8px 24px #00000026}.video-result-actions{display:flex;gap:16px;justify-content:center}.download-video-btn{background:#4caf50;color:#fff;font-size:18px;padding:16px 32px;border-radius:8px}.regenerate-video-btn{background:#f5f5f5;color:#666;font-size:18px;padding:16px 32px;border-radius:8px}.video-info{margin-top:40px;padding:24px;background:#f9f9f9;border-radius:12px}.video-info h3{font-size:20px;color:#333;margin-bottom:16px}.video-info ul{list-style:none;padding:0}.video-info li{padding:8px 0;color:#666;font-size:16px;border-bottom:1px solid #e0e0e0}.video-info li:last-child{border-bottom:none}.language-selector{position:relative}.language-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff3;color:#fff;border:2px solid white;border-radius:8px;cursor:pointer;font-size:16px;transition:all .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.language-button:hover{background:#ffffff4d;transform:translateY(-2px)}.language-button .flag{font-size:20px}.language-button .language-name{font-weight:500}.language-button .arrow{font-size:12px;margin-left:4px}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;min-width:200px;z-index:1000;overflow:hidden}.language-option{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:#fff;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer;font-size:16px;text-align:left;transition:background .2s}.language-option:last-child{border-bottom:none}.language-option:hover{background:#f9f9f9}.language-option.active{background:#e3f2fd;color:#2196f3;font-weight:600}.language-option .flag{font-size:24px}.language-option .language-name{flex:1}.language-option .checkmark{color:#4caf50;font-weight:700;font-size:18px}@media (max-width: 768px){.header-menu .language-selector{width:100%}.header-menu .language-button{width:100%;background:#667eea;border:none;padding:12px 16px;font-size:14px;justify-content:space-between}.header-menu .language-button:hover{background:#5568d3;transform:none}.header-menu .language-dropdown{position:static;box-shadow:none;border-radius:0;margin-top:8px}.header-menu .language-option{font-size:14px;padding:10px 16px}}.admin-panel .language-selector .language-button,.main .language-selector .language-button{background:#667eea;color:#fff;border-color:#667eea}.admin-panel .language-selector .language-button:hover,.main .language-selector .language-button:hover{background:#5568d3;border-color:#5568d3}.tour-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:9998;animation:fadeIn .3s ease}.tour-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;padding:40px;max-width:500px;width:90%;z-index:9999;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.tour-content{text-align:center}.tour-icon{font-size:64px;margin-bottom:20px;animation:bounce .6s ease}.tour-modal h2{font-size:28px;color:#333;margin-bottom:16px}.tour-modal p{font-size:16px;color:#666;line-height:1.6;margin-bottom:32px}.tour-progress{display:flex;justify-content:center;gap:8px;margin-bottom:32px}.tour-dot{width:10px;height:10px;border-radius:50%;background:#e0e0e0;transition:all .3s ease}.tour-dot.active{background:#667eea;width:24px;border-radius:5px}.tour-dot.completed{background:#4caf50}.tour-actions{display:flex;gap:12px;justify-content:center}.tour-skip{padding:12px 24px;background:transparent;color:#666;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.tour-skip:hover{background:#f5f5f5;border-color:#ccc}.tour-next{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}.tour-next:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width: 768px){.tour-modal{padding:32px 24px;max-width:90%}.tour-icon{font-size:48px}.tour-modal h2{font-size:24px}.tour-modal p{font-size:14px}.tour-actions{flex-direction:column}.tour-skip,.tour-next{width:100%}}.admin-panel{padding:40px;max-width:1200px;margin:0 auto}.admin-header{margin-bottom:40px}.admin-header h2{font-size:32px;color:#333;margin-bottom:8px}.admin-header p{font-size:16px;color:#666}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:20px;transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.stat-icon{font-size:48px;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px}.stat-content h3{font-size:36px;color:#333;margin:0 0 4px}.stat-content p{font-size:14px;color:#666;margin:0}.admin-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.info-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.info-card h3{font-size:20px;color:#333;margin-bottom:20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row span:first-child{font-weight:500;color:#666}.info-value{color:#667eea;font-weight:600}@media (max-width: 768px){.admin-panel{padding:20px}.admin-header h2{font-size:24px}.admin-stats{grid-template-columns:1fr;gap:16px}.stat-card{padding:20px}.stat-icon{font-size:36px;width:60px;height:60px}.stat-content h3{font-size:28px}.admin-info{grid-template-columns:1fr}}.privacy-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.privacy-modal{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.privacy-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid #f0f0f0}.privacy-header h2{font-size:28px;color:#333;margin:0}.close-btn{background:#f5f5f5;border:none;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#e0e0e0;transform:rotate(90deg)}.privacy-content{flex:1;overflow-y:auto;padding:32px}.last-updated{color:#999;font-size:14px;font-style:italic;margin-bottom:24px}.privacy-content section{margin-bottom:32px}.privacy-content h3{font-size:20px;color:#667eea;margin-bottom:12px}.privacy-content p{color:#666;line-height:1.8;margin-bottom:12px}.privacy-content ul{margin-left:20px;margin-bottom:16px}.privacy-content li{color:#666;line-height:1.8;margin-bottom:8px}.privacy-content strong{color:#333;font-weight:600}.consent-section{background:#f0f4ff;padding:20px;border-radius:8px;border-left:4px solid #667eea;margin-top:32px}.consent-section p{color:#333;font-size:16px;margin:0}.privacy-footer{padding:20px 32px;border-top:2px solid #f0f0f0;display:flex;justify-content:flex-end}.close-footer-btn{background:#667eea;color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:16px;cursor:pointer;transition:all .2s}.close-footer-btn:hover{background:#5568d3;transform:translateY(-2px)}@media (max-width: 768px){.privacy-overlay{padding:0}.privacy-modal{max-height:100vh;border-radius:0}.privacy-header,.privacy-content,.privacy-footer{padding:20px}.privacy-header h2{font-size:24px}.privacy-content h3{font-size:18px}}.app{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden;width:100%;max-width:100%}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px 40px}.header-content{display:flex;justify-content:space-between;align-items:center}.header-title h1{font-size:32px;margin-bottom:4px}.header-title p{font-size:16px;opacity:.9}.header-actions{position:relative;display:flex;gap:12px;align-items:center}.hamburger-btn{display:flex;background:#fff3;color:#fff;padding:10px 16px;font-size:24px;border:2px solid white;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:48px;height:48px;align-items:center;justify-content:center}.header-menu{display:none;position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:12px;min-width:200px;z-index:1000;flex-direction:column;gap:8px}.header-menu.open{display:flex}.header-menu .export-btn,.header-menu .logout-btn,.header-menu .menu-btn{width:100%;background:#667eea;color:#fff;border:none;padding:12px 16px;font-size:14px;text-align:left;border-radius:6px;cursor:pointer;transition:background .2s}.header-menu .export-btn:hover,.header-menu .logout-btn:hover,.header-menu .menu-btn:hover{background:#5568d3}.header-menu .menu-btn.admin-btn{width:100%;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:12px 16px;font-size:14px;text-align:left;border-radius:6px}.header-menu .menu-btn.admin-btn:hover{background:linear-gradient(135deg,#e082ea,#e4465b)}.export-btn,.logout-btn{background:#fff3;color:#fff;padding:10px 20px;font-size:14px;border:2px solid white;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.export-btn:hover,.logout-btn:hover{background:#ffffff4d}.nav{display:flex;gap:0;background:#f5f5f5;border-bottom:2px solid #e0e0e0;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav button{flex:1;min-width:120px;padding:20px 16px;background:transparent;border:none;border-radius:0;font-size:16px;font-weight:500;color:#666;transition:all .3s ease;white-space:nowrap}.nav button:hover{background:#e8e8e8;transform:none;box-shadow:none}.nav button.active{background:#fff;color:#667eea;border-bottom:3px solid #667eea}.nav button:disabled{color:#ccc}.main-with-sidebar{display:flex;height:calc(100vh - 300px);overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:20px;background:#fff}.main{padding:40px;min-height:500px}.app-footer{background:#f5f5f5;border-top:1px solid #e0e0e0;padding:20px 40px;text-align:center;color:#666;font-size:14px}.app-footer p{margin:0}.privacy-link{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:14px;padding:0;margin-left:4px}.privacy-link:hover{color:#5568d3}@media (max-width: 768px){.app{border-radius:0;box-shadow:none;width:100%;max-width:100%;min-height:100vh;margin:0}.header{padding:16px}.header-content{flex-direction:row;align-items:center;gap:12px}.header-title h1{font-size:20px;margin-bottom:2px}.header-title p{font-size:12px}.hamburger-btn{display:flex}.header-menu .export-btn,.header-menu .logout-btn,.header-menu .menu-btn{width:100%;background:#667eea;color:#fff;border:none;padding:12px 16px;font-size:14px;text-align:left}.header-menu .admin-btn{background:linear-gradient(135deg,#f093fb,#f5576c)}.header-menu .export-btn:hover,.header-menu .logout-btn:hover,.header-menu .menu-btn:hover{background:#5568d3}.header-menu .admin-btn:hover{background:linear-gradient(135deg,#e082ea,#e4465b)}.nav{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.nav::-webkit-scrollbar{display:none}.nav button{min-width:100px;padding:16px 12px;font-size:14px}.main-with-sidebar{flex-direction:column;height:auto;min-height:calc(100vh - 200px)}.main-content{padding:16px}.main{padding:16px;min-height:auto}.app-footer{padding:16px;font-size:12px}}@media (max-width: 480px){.header-title h1{font-size:18px}.header-title p{font-size:11px}.nav button{min-width:90px;padding:14px 8px;font-size:13px}}*{margin:0;padding:0;box-sizing:border-box}html{width:100%;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px;width:100%;overflow-x:hidden}#root{max-width:1400px;width:100%;margin:0 auto}button{cursor:pointer;font-size:16px;padding:12px 24px;border:none;border-radius:8px;transition:all .3s ease}button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){html{width:100%;overflow-x:hidden}body{padding:0;margin:0;width:100%;overflow-x:hidden}#root{max-width:100%;width:100%;margin:0;padding:0}button:hover{transform:none}}
