*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;color:var(--text-primary);background-color:var(--bg-primary)}#root{width:100%;height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0}button{font-family:inherit;cursor:pointer;transition:all .2s}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--brand-color);outline-offset:2px}::selection{background-color:var(--brand-color);color:#fff}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:1rem}.login-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:2rem;width:100%;max-width:400px}.login-title{font-size:2rem;font-weight:600;text-align:center;margin-bottom:.5rem;color:#333}.login-subtitle{text-align:center;color:#666;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:500;color:#333}.form-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#4a90e2}.form-input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{color:#d32f2f;font-size:.875rem;padding:.5rem;background:#ffebee;border-radius:4px;text-align:center}.submit-button{padding:.75rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.submit-button:hover:not(:disabled){background:#357abd}.submit-button:disabled{background:#ccc;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center}.security-note{font-size:.875rem;color:#666}.skeleton{display:inline-block;background:linear-gradient(90deg,var(--skeleton-base, #e0e0e0) 0%,var(--skeleton-highlight, #f0f0f0) 50%,var(--skeleton-base, #e0e0e0) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}@media (prefers-color-scheme: dark){:root{--skeleton-base: #2d3748;--skeleton-highlight: #4a5568}}@media (prefers-reduced-motion: reduce){.skeleton{animation:none}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{border-radius:4px}.skeleton-circular{border-radius:50%}.skeleton-rectangular{border-radius:8px}.message-skeleton{padding:1rem;border-bottom:1px solid var(--border-color)}.message-skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-skeleton-content{display:flex;flex-direction:column;gap:.5rem}.thread-skeleton{padding:1rem;border-bottom:1px solid var(--border-color)}.thread-skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.thread-list{background:#fff;height:100%;display:flex;flex-direction:column}.thread-list-title{font-size:1.25rem;font-weight:600;padding:1rem;margin:0;border-bottom:1px solid #e0e0e0}.thread-list-loading,.thread-list-error{padding:2rem;text-align:center;color:#666}.thread-list-items{flex:1;overflow-y:auto}.thread-item{width:100%;padding:1rem;border:none;border-bottom:1px solid #f0f0f0;background:#fff;text-align:left;cursor:pointer;transition:background .2s}.thread-item:hover{background:#f9f9f9}.thread-item.selected{background:#e3f2fd;border-left:3px solid #4a90e2}.thread-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.thread-participants{font-size:1rem;font-weight:500;margin:0;color:#333}.thread-date{font-size:.75rem;color:#999}.thread-item-info{display:flex;flex-direction:column;gap:.25rem}.thread-message-count{font-size:.875rem;color:#666}.thread-preview{font-size:.875rem;color:#666;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-list-container{height:100%;display:flex;flex-direction:column}.message-list{flex:1;overflow:auto;padding:1rem}.message-list-empty,.message-list-loading,.message-list-error{padding:2rem;text-align:center;color:#666}.message-row{padding:1rem;border-bottom:1px solid #f0f0f0;transition:background .2s}.message-row:hover{background:#f9f9f9}.message-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.message-sender{font-weight:500;color:#333}.message-time{font-size:.875rem;color:#999}.message-content{display:flex;flex-direction:column;gap:.5rem}.message-play-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background .2s;width:fit-content}.message-play-button:hover{background:#357abd}.message-text{color:#666}.message-transcription{margin:0;color:#666;font-size:.875rem;line-height:1.5}.message-attachments{font-size:.875rem;color:#999}.message-list-loading-more{padding:1rem;text-align:center;color:#666}.audio-player{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;margin-bottom:1rem}.player-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-sender{font-size:1.125rem;font-weight:600;color:#333;margin:0}.player-date{color:#666;font-size:.875rem}.player-error{color:#d32f2f;font-size:.875rem;margin-bottom:1rem}.player-progress-container{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.player-time{font-size:.875rem;color:#666;min-width:45px}.progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;cursor:pointer;position:relative}.progress-track{height:100%;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#4a90e2;transition:width .1s ease}.player-controls{display:flex;align-items:center;justify-content:center;gap:1rem}.control-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:background .2s}.control-button:hover{background:#f5f5f5}.play-button{font-size:2rem}.volume-slider{width:100px}.player-transcription{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.player-transcription p{color:#666;font-size:.875rem;line-height:1.5;margin:0}.mini-audio-player{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -2px 8px #0000001a;z-index:1000}.mini-player-progress{height:3px;background:#4a90e2;transition:width .1s ease}.mini-player-content{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem}.mini-player-sender{font-weight:500}.mini-play-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem}.search-bar{display:flex;gap:.5rem;max-width:400px}.search-input{flex:1;padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:.875rem}.search-input:focus{outline:none;border-color:#4a90e2}.search-button{padding:.5rem 1rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.search-button:hover:not(:disabled){background:#357abd}.search-button:disabled{background:#ccc;cursor:not-allowed}.search-results-container{height:100%;display:flex;flex-direction:column;background:#fff}.search-results-header{padding:1rem;border-bottom:1px solid #e0e0e0}.search-results-header h2{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#333}.search-results-count{margin:0;font-size:.875rem;color:#666}.search-results-list{flex:1;overflow:auto;position:relative}.search-results-loading,.search-results-error,.search-results-empty{padding:2rem;text-align:center;color:#666}.search-results-error{color:#d32f2f}.search-result-item{padding:1rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.search-result-item:hover{background:#f9f9f9}.search-result-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.search-result-sender{font-weight:500;color:#333}.search-result-time{font-size:.875rem;color:#999}.search-result-content{margin-bottom:.5rem}.search-result-highlight{font-size:.875rem;line-height:1.5;color:#666}.search-result-highlight mark{background:#ffeb3b;font-weight:500}.search-result-text{margin:0;font-size:.875rem;line-height:1.5;color:#666;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.search-result-no-content{margin:0;font-size:.875rem;color:#999;font-style:italic}.search-result-play-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;margin-top:.5rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background .2s}.search-result-play-button:hover{background:#357abd}.search-result-meta{display:flex;justify-content:space-between;font-size:.75rem;color:#999}.search-result-score{color:#4a90e2}.search-results-loading-more{padding:1rem;text-align:center;color:#666;font-size:.875rem}@media (max-width: 768px){.search-results-header{padding:1rem}.search-result-item{padding:.75rem}}.search-page{height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.search-page-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;box-shadow:0 2px 4px #0000001a}.search-back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:1px solid #ddd;border-radius:4px;font-size:1rem;color:#333;cursor:pointer;transition:all .2s}.search-back-button:hover{background:#f5f5f5;border-color:#4a90e2;color:#4a90e2}.search-type-selector{display:flex;gap:1rem}.search-type-selector label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666;cursor:pointer}.search-type-selector input[type=radio]{cursor:pointer}.search-page-empty{padding:4rem 2rem;text-align:center}.search-page-empty h2{margin:0 0 1rem;font-size:1.5rem;color:#333}.search-page-empty p{margin:0 0 2rem;color:#666}.search-page-empty .search-back-button{display:inline-flex;background:#4a90e2;color:#fff;border:none}.search-page-empty .search-back-button:hover{background:#357abd}.search-page .search-results-container{flex:1;margin:0}@media (max-width: 768px){.search-page-header{padding:1rem;flex-direction:column;gap:1rem}.search-type-selector{width:100%;justify-content:center}}:root{color-scheme:light dark;--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #f9f9f9;--text-primary: #333333;--text-secondary: #666666;--text-muted: #999999;--border-color: #e0e0e0;--brand-color: #4a90e2;--brand-hover: #357abd;--shadow-light: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15)}@media (prefers-color-scheme: dark){:root{--bg-primary: #0f1115;--bg-secondary: #151922;--bg-tertiary: #1e2430;--text-primary: #e6e6e6;--text-secondary: #9aa4b2;--text-muted: #6b7280;--border-color: #2d3748;--brand-color: #4a90e2;--brand-hover: #5ba0f2;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .5)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}*{transition:background-color .2s ease,color .2s ease,border-color .2s ease}.app{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);color:var(--text-primary)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.25rem;color:var(--text-secondary)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);box-shadow:0 2px 4px var(--shadow-light);z-index:100}.app-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.app-content{flex:1;display:flex;overflow:hidden}.app-sidebar{width:300px;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:1rem;gap:1rem}.mobile-layout{flex:1;display:flex;flex-direction:column}.back-button{padding:1rem;background:var(--bg-secondary);border:none;border-bottom:1px solid var(--border-color);text-align:left;font-size:1rem;color:var(--brand-color);cursor:pointer}.back-button:hover{background:var(--bg-tertiary)}@media (max-width: 768px){.app-header{flex-direction:column;gap:1rem;padding:1rem}.app-title{font-size:1.25rem}.search-bar{width:100%}.app-content{padding-bottom:60px}}
