*{margin:0;padding:0;box-sizing:border-box}body{font-family:-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-color:#f5f5f5;padding:20px}.container{max-width:1200px;margin:0 auto}h1{color:#333;margin-bottom:30px;text-align:center}h2{color:#555;margin-top:30px;margin-bottom:15px;border-bottom:2px solid #ddd;padding-bottom:10px}.section{background:#fff;padding:20px;margin-bottom:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.item{padding:15px;margin-bottom:10px;background:#f9f9f9;border-left:4px solid #4CAF50;border-radius:4px}.item h3{color:#333;margin-bottom:8px}.item p{color:#666;line-height:1.6}.item .uuid{font-size:.85em;color:#999;font-family:monospace;margin-top:8px}.loading{text-align:center;padding:40px;color:#666}.error{background:#ffebee;color:#c62828;padding:20px;border-radius:8px;margin:20px 0;border-left:4px solid #c62828}.empty{color:#999;font-style:italic;padding:10px}.fact-entities{margin-top:8px;font-size:.9em;color:#777}.fact-entities span{display:inline-block;background:#e3f2fd;padding:2px 8px;margin-right:5px;margin-top:5px;border-radius:12px;font-family:monospace;font-size:.85em}.button{display:inline-block;padding:10px 20px;background:#4caf50;color:#fff;text-decoration:none;border-radius:4px;font-weight:500;transition:background .3s}.button:hover{background:#45a049}.button-small{padding:6px 12px;font-size:14px}.badge{display:inline-block;background:#2196f3;color:#fff;padding:4px 10px;border-radius:12px;font-size:.85em;margin-left:8px;font-weight:500}form{max-width:600px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}form div{margin-bottom:15px}form label{display:block;margin-bottom:5px;color:#555;font-weight:500}form input[type=text],form input[type=email],form input[type=password],form input[type=number],form textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}form input[type=checkbox]{margin-right:8px}form textarea{min-height:100px;resize:vertical}form button[type=submit]{background:#4caf50;color:#fff;padding:10px 20px;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:background .3s}form button[type=submit]:hover{background:#45a049}.app-layout{display:flex;flex-direction:column;min-height:100vh;margin:-20px;background-color:#f5f5f5}.app-body{display:flex;flex:1}.sidebar{width:280px;background:#fff;border-right:1px solid #ddd;overflow-y:auto;flex-shrink:0}.sidebar-content{padding:20px}.sidebar-world{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #4CAF50}.sidebar-world h2{color:#333;margin:0;padding:0;border:none;font-size:1.5em}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.sidebar-section{border-radius:4px;overflow:hidden}.sidebar-heading{width:100%;padding:12px 16px;background:#f5f5f5;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:1em;font-weight:600;color:#555;transition:background .2s,color .2s;text-align:left}.sidebar-heading:hover{background:#e8e8e8;color:#333}.sidebar-heading.open{background:#4caf50;color:#fff}.sidebar-heading.open:hover{background:#45a049}.accordion-icon{font-size:.8em;transition:transform .2s}.sidebar-list{list-style:none;padding:0;margin:0;background:#fafafa}.sidebar-list li{border-bottom:1px solid #eee}.sidebar-list li:last-child{border-bottom:none}.sidebar-link{display:block;padding:10px 16px;color:#555;text-decoration:none;transition:background .2s,color .2s,padding-left .2s}.sidebar-link:hover{background:#f0f0f0;color:#4caf50;padding-left:20px}.sidebar-empty{padding:10px 16px;color:#999;font-style:italic;font-size:.9em}.main-area{flex:1;display:flex;flex-direction:column;overflow-x:auto}.main-content{flex:1;padding:20px}.transcribe-content{display:flex;flex-direction:column;gap:20px}.mode-tabs{display:flex;gap:8px;margin-bottom:20px}.tab{flex:1;padding:12px 16px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#495057;font-size:1rem;cursor:pointer;transition:all .2s ease}.tab:hover{background:#e9ecef}.tab.active{background:#4caf50;border-color:#4caf50;color:#fff}.drop-zone{border:2px dashed #dee2e6;border-radius:12px;padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s ease;background:#f8f9fa}.drop-zone:hover,.drop-zone.dragging{border-color:#4caf50;background:#e8f5e9}.drop-zone.has-file{border-style:solid;cursor:default}.drop-prompt{display:flex;flex-direction:column;align-items:center;gap:8px}.drop-prompt .upload-icon{font-size:48px;margin-bottom:8px}.drop-prompt .or-text{color:#6c757d;font-size:.9rem}.drop-prompt .supported-formats{color:#adb5bd;font-size:.8rem;margin-top:8px}.file-info{display:flex;align-items:center;gap:12px;justify-content:center}.file-info .file-icon{font-size:32px}.file-info .file-name{font-weight:500;color:#333}.file-info .file-size{color:#6c757d;font-size:.9rem}.clear-btn{padding:4px 12px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;color:#6c757d;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#e9ecef;color:#495057}.record-area{background:#fff;padding:24px;border-radius:12px;border:1px solid #dee2e6}.device-select{display:flex;align-items:center;gap:12px;margin-bottom:24px}.device-select label{font-weight:500;color:#495057}.device-select select{flex:1;padding:8px 12px;border:1px solid #dee2e6;border-radius:4px;font-size:14px}.recording-indicator{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;background:#f8f9fa;border-radius:8px;margin-bottom:24px}.recording-indicator.active{background:#ffebee}.record-dot{width:16px;height:16px;border-radius:50%;background:#ccc}.recording-indicator.active .record-dot{background:#f44336;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.record-time{font-size:2rem;font-weight:600;font-family:monospace;color:#333}.record-controls{display:flex;justify-content:center}.record-btn{padding:12px 32px;font-size:1rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.record-btn.start{background:#4caf50;color:#fff}.record-btn.start:hover{background:#45a049}.record-btn.stop{background:#f44336;color:#fff}.record-btn.stop:hover{background:#d32f2f}.record-btn:disabled{background:#ccc;cursor:not-allowed}.recording-ready{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;padding:12px;background:#e8f5e9;border-radius:8px;color:#2e7d32}.process-btn{width:100%;padding:16px;font-size:1.1rem;margin-top:8px}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;border-left:4px solid #c62828}.job-progress{display:flex;align-items:center;justify-content:center;gap:16px;padding:24px;background:#e3f2fd;border-radius:8px}.spinner{width:24px;height:24px;border:3px solid #bbdefb;border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-section{background:#fff;padding:24px;border-radius:12px;border:1px solid #dee2e6}.result-section h2{margin-top:0;margin-bottom:16px}.result-meta{display:flex;gap:24px;margin-bottom:16px;color:#6c757d;font-size:.9rem}.fragments-list{max-height:400px;overflow-y:auto;border:1px solid #eee;border-radius:8px}.fragment{padding:12px 16px;border-bottom:1px solid #eee;border-left:3px solid #4CAF50}.fragment:last-child{border-bottom:none}.fragment-time{font-family:monospace;font-size:.85rem;color:#6c757d;margin-bottom:4px}.fragment-text{color:#333;line-height:1.5}.result-actions{margin-top:16px;display:flex;gap:12px}.download-btn{background:#2196f3}.download-btn:hover{background:#1976d2}.job-history{margin-top:32px}.job-history h2{margin-top:0}.no-jobs{color:#999;font-style:italic;text-align:center;padding:24px}.jobs-list{display:flex;flex-direction:column;gap:8px}.job-item{padding:12px 16px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;cursor:pointer;transition:all .2s}.job-item:hover{background:#e9ecef}.job-item.selected{background:#e8f5e9;border-color:#4caf50}.job-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.job-filename{font-weight:500;color:#333}.job-status{padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.job-status.status-pending{background:#fff3e0;color:#e65100}.job-status.status-processing{background:#e3f2fd;color:#1565c0}.job-status.status-completed{background:#e8f5e9;color:#2e7d32}.job-status.status-failed{background:#ffebee;color:#c62828}.job-meta{display:flex;gap:16px;font-size:.8rem;color:#6c757d}.job-type-badge{font-size:1.1rem;margin-right:8px}.job-actions{display:flex;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #e9ecef}.action-btn{padding:4px 12px;border:1px solid #dee2e6;border-radius:4px;background:#fff;cursor:pointer;font-size:1rem;transition:all .2s}.action-btn:hover{background:#e9ecef;border-color:#adb5bd}.job-type-llm_edit{border-left:3px solid #9c27b0}.job-type-transcription{border-left:3px solid #2196f3}.llm-result{border-left:4px solid #9c27b0}.llm-output{background:#f5f5f5;padding:16px;border-radius:8px;max-height:400px;overflow-y:auto}.llm-output pre{margin:0;white-space:pre-wrap;word-wrap:break-word;font-family:inherit;font-size:.95rem;line-height:1.6}.result-actions{display:flex;gap:12px;margin-top:16px}.primary-btn{background:#4caf50!important;color:#fff!important;border:none!important}.primary-btn:hover{background:#45a049!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333;border-bottom:none;padding-bottom:0}.modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-close:hover{background:#f5f5f5}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group select,.form-group input[type=number]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:.95rem;transition:border-color .2s}.form-group select:focus,.form-group input[type=number]:focus{outline:none;border-color:#4caf50}.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.form-hint{display:block;margin-top:4px;font-size:.85rem;color:#666}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #c62828;font-size:.9rem}.success-message{background:#e8f5e9;color:#2e7d32;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #2e7d32;font-size:.9rem}.generate-button{width:100%;padding:12px;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.generate-button:hover:not(:disabled){background:#45a049}.generate-button:disabled{background:#ccc;cursor:not-allowed}.invitation-result{margin-top:20px}.invitation-result label{display:block;margin-bottom:8px;font-weight:500;color:#333}.link-display{display:flex;gap:8px}.link-input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:monospace;background:#f9f9f9}.copy-button{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:background .2s}.copy-button:hover{background:#1976d2}.uploads-section{margin-bottom:24px}.section-header.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.section-header.collapsible:hover{background:#f8f9fa;border-radius:8px}.section-header.collapsible h2{display:flex;align-items:center;gap:8px;margin:0;padding:12px;border-bottom:none}.chevron{display:inline-block;transition:transform .2s ease;font-size:.75rem;color:#6c757d}.chevron.expanded{transform:rotate(90deg)}.chevron.small{font-size:.65rem}.count-badge{background:#e9ecef;color:#495057;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:500;margin-left:8px}.uploads-content{padding-top:12px}.no-uploads{color:#999;font-style:italic;text-align:center;padding:24px}.uploads-list{display:flex;flex-direction:column;gap:12px}.upload-item{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.upload-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s}.upload-header:hover{background:#e9ecef}.upload-info{display:flex;align-items:center;gap:8px;flex:1;min-width:200px}.upload-filename{font-weight:500;color:#333;word-break:break-word}.upload-status{padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.upload-status.status-new{background:#e3f2fd;color:#1565c0}.upload-status.status-transcribed{background:#e8f5e9;color:#2e7d32}.upload-status.status-deleted{background:#f5f5f5;color:#757575}.upload-meta{display:flex;gap:16px;font-size:.8rem;color:#6c757d;flex-wrap:wrap}.upload-expiry{color:#f57c00}.upload-actions{display:flex;gap:8px}.action-btn.delete-btn:hover{background:#ffebee;border-color:#ef9a9a}.upload-jobs{background:#fff;border-top:1px solid #dee2e6;padding:12px 16px}.no-jobs-text{color:#999;font-style:italic;font-size:.9rem;margin:0;padding:8px 0}.nested-job-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f8f9fa;border-radius:4px;margin-bottom:8px;cursor:pointer;transition:background .2s}.nested-job-item:last-child{margin-bottom:0}.nested-job-item:hover{background:#e9ecef}.nested-job-item.selected{background:#e8f5e9;border:1px solid #4CAF50}.nested-job-item .job-date{font-size:.8rem;color:#6c757d}.nested-job-item .job-progress{font-size:.8rem;color:#1976d2;font-weight:500}.modal-content h3{margin:0 0 16px;padding:20px 24px 0;color:#333}.modal-content>p{padding:0 24px;margin:0 0 8px;color:#555}.filename-highlight{padding:0 24px;margin:0 0 16px;font-weight:600;color:#333;word-break:break-word}.warning-message{background:#fff3e0;color:#e65100;padding:12px 16px;margin:0 24px 16px;border-radius:4px;border-left:4px solid #ff9800;font-size:.9rem}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px 20px;border-top:1px solid #e0e0e0}.secondary-btn{background:#f5f5f5!important;color:#333!important;border:1px solid #ddd!important}.secondary-btn:hover{background:#e0e0e0!important}.danger-btn{background:#f44336!important;color:#fff!important;border:none!important}.danger-btn:hover{background:#d32f2f!important}.upload-name-section{display:flex;flex-direction:column;gap:12px}.name-input-group{display:flex;flex-direction:column;gap:6px}.name-input-group label{font-weight:500;color:#495057;font-size:.9rem}.name-input{padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.name-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.name-input::placeholder{color:#adb5bd}.upload-original-name{font-size:.75rem;color:#6c757d;margin-left:4px}.rename-form{padding:0 24px 16px}.rename-form label{display:block;margin-bottom:8px;font-weight:500;color:#333}.rename-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:.95rem;transition:border-color .2s}.rename-input:focus{outline:none;border-color:#4caf50}.original-filename-hint{margin-top:8px;font-size:.85rem;color:#6c757d}.landing-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);margin:-20px;padding:0}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:#fff;box-shadow:0 2px 4px #0000001a}.landing-logo h1{margin:0;color:#4caf50;font-size:1.8rem}.landing-nav{display:flex;align-items:center;gap:16px}.landing-hero{padding:80px 40px;text-align:center;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.hero-content{max-width:800px;margin:0 auto}.hero-content h2{font-size:2.5rem;margin:0 0 24px;border:none;color:#fff;padding:0}.hero-description{font-size:1.2rem;line-height:1.8;opacity:.95}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:60px 40px;max-width:1200px;margin:0 auto}.feature-card{background:#fff;padding:32px;border-radius:12px;box-shadow:0 4px 12px #00000014;text-align:center;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.feature-icon{font-size:3rem;margin-bottom:16px}.feature-card h3{color:#333;margin:0 0 12px;font-size:1.25rem}.feature-card p{color:#666;line-height:1.6;margin:0}.landing-cta{background:#f8f9fa;padding:60px 40px;text-align:center}.cta-content{max-width:600px;margin:0 auto}.cta-content h3{color:#333;font-size:1.5rem;margin:0 0 16px}.cta-content p{color:#666;line-height:1.6;margin:0 0 12px}.cta-contact{margin-top:20px!important}.cta-contact a{color:#4caf50;font-weight:500}.cta-contact a:hover{text-decoration:underline}.landing-footer{background:#333;color:#999;padding:24px 40px;text-align:center}.landing-footer p{margin:0;font-size:.9rem}@media (max-width: 768px){.landing-header{padding:16px 20px;flex-direction:column;gap:16px}.landing-hero{padding:48px 20px}.hero-content h2{font-size:1.75rem}.hero-description{font-size:1rem}.landing-features,.landing-cta{padding:40px 20px}}.account-page .section{max-width:800px;margin:0 auto}.account-section{margin-bottom:32px}.account-section h2{margin-top:0;margin-bottom:16px;font-size:1.25rem}.account-info{background:#f8f9fa;padding:16px;border-radius:8px}.account-field{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid #e9ecef}.account-field:last-child{border-bottom:none}.account-label{font-weight:500;color:#495057;width:120px;flex-shrink:0}.account-value{color:#333}.account-list{display:flex;flex-direction:column;gap:8px}.account-list-item{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8f9fa;border-radius:6px;transition:background .2s}.account-list-item:hover{background:#e9ecef}.account-link{color:#4caf50;text-decoration:none;font-weight:500}.account-link:hover{text-decoration:underline}.account-role,.account-world-name{color:#6c757d;font-size:.9rem}.empty-message{color:#6c757d;font-style:italic;padding:16px;text-align:center;background:#f8f9fa;border-radius:6px}.form-error{color:#dc3545;font-size:.85rem;margin-top:4px;display:block}
