:root{--color-card-bg:#fff;--color-text-primary:#1a202c;--color-text-secondary:#4a5568;--color-success:#48bb78}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--color-background);color:#1a202c;color:var(--color-text-primary);font-family:Inter,Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}#root{display:flex;flex-direction:column;min-height:100vh}.fade-in{animation:fadeIn .4s ease-in}.loading-spinner{border:4px solid #e2e8f0;border-top-color:#2b6cb0;border:4px solid var(--color-border);border-top-color:var(--color-primary);height:40px;width:40px}.navbar{background:var(--color-card-bg);border-bottom:1px solid var(--color-border);box-shadow:0 2px 4px #0000000d;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-container{justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 1.5rem}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{color:var(--color-text-primary);font-size:1.5rem;font-weight:700;gap:.75rem;text-decoration:none}.navbar-logo-icon{color:var(--color-primary)}.navbar-menu{gap:2rem;list-style:none}.navbar-link,.navbar-menu{align-items:center;display:flex}.navbar-link{color:var(--color-text-secondary);font-weight:500;gap:.5rem;position:relative;text-decoration:none;transition:color .2s}.navbar-link.active,.navbar-link:hover{color:var(--color-primary)}.navbar-link.active:after{background:var(--color-primary);bottom:-.5rem;content:"";height:2px;left:0;position:absolute;right:0}.navbar-toggle{background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:none;padding:.5rem}@media (max-width:768px){.navbar-menu{background:var(--color-card-bg);box-shadow:0 4px 6px #0000001a;flex-direction:column;gap:0;left:0;opacity:0;padding:1rem;pointer-events:none;position:fixed;right:0;top:73px;transform:translateY(-100%);transition:transform .3s,opacity .3s}.navbar-menu.open{opacity:1;pointer-events:all;transform:translateY(0)}.navbar-menu li{width:100%}.navbar-link{display:flex;padding:1rem;width:100%}.navbar-link.active:after{display:none}.navbar-toggle{display:block}}.sidebar{background:var(--color-card-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .3s;width:260px}.sidebar-link{align-items:center;border-radius:8px;color:var(--color-text-secondary);display:flex;font-weight:500;gap:.75rem;padding:.875rem 1rem;text-decoration:none;transition:all .2s}.sidebar-link:hover{background:#2b6cb014;color:var(--color-primary)}.sidebar-link.active{background:#2b6cb01f;color:var(--color-primary)}.sidebar-section{border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1.5rem}.sidebar-section-title{color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;padding:0 1rem;text-transform:uppercase}@media (max-width:1024px){.sidebar{bottom:0;box-shadow:2px 0 8px #0000001a;left:0;position:fixed;top:73px;transform:translateX(-100%);z-index:50}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;top:73px;z-index:40}.sidebar-overlay.open{display:block}}@media (min-width:1025px){.sidebar-overlay{display:none}}.footer{background:var(--color-card-bg);border-top:1px solid var(--color-border);margin-top:auto;padding:2rem 0}.footer-container{margin:0 auto;max-width:1400px;padding:0 1.5rem;text-align:center}.footer-content{flex-direction:column;gap:1rem}.footer-content,.footer-logo{align-items:center;display:flex}.footer-logo{color:var(--color-primary);font-size:1.125rem;font-weight:600;gap:.5rem}.footer-copyright,.footer-tagline{color:var(--color-text-secondary);font-size:.875rem}@media (max-width:768px){.footer{padding:1.5rem 0}}.feature-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;color:inherit;display:block;padding:2rem;text-decoration:none;transition:all .3s}.feature-card:hover{border-color:var(--color-primary);box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.feature-card-icon{align-items:center;border-radius:12px;display:flex;height:48px;justify-content:center;margin-bottom:1rem;width:48px}.feature-card-icon.primary{background:#2b6cb01a;color:var(--color-primary)}.feature-card-icon.secondary{background:#38a1691a;color:var(--color-secondary)}.feature-card-icon.accent{background:#f6ad551a;color:var(--color-accent)}.feature-card h3{font-size:1.25rem;margin-bottom:.5rem}.feature-card p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:0}.home{padding:0}.hero{background:linear-gradient(135deg,#2b6cb00d,#38a1690d);border-bottom:1px solid var(--color-border);padding:4rem 2rem;text-align:center}.hero h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;background-clip:text;font-size:3rem;margin-bottom:1rem}.hero-tagline{color:var(--color-text-secondary);font-size:1.25rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.features-section{margin:0 auto;max-width:1200px;padding:4rem 2rem}.features-section h2{font-size:2.5rem;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width:768px){.hero h1{font-size:2rem}.hero-tagline{font-size:1rem}.features-section{padding:2rem 1rem}.features-section h2{font-size:1.75rem}.features-grid{grid-template-columns:1fr}}.translate{margin:0 auto;max-width:1200px}.translate h1{color:#1a202c;color:var(--color-text);margin-bottom:2rem}.translate-controls .input-group{min-width:200px}.translate-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.translate-panel{display:flex;flex-direction:column}.translate-panel h3{color:#1a202c;color:var(--color-text);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.ai-status{background:#2b6cb00d;border:1px solid #2b6cb01a;color:#2b6cb0;color:var(--color-primary)}.feedback-section h3{color:#1a202c;color:var(--color-text);font-weight:600;margin-bottom:1rem}.feedback-btn:disabled{cursor:not-allowed;opacity:.5}.vocabulary-section{margin-top:1.5rem}.vocabulary-section h3{font-weight:600;margin-bottom:.5rem}.textarea,.vocabulary-section h3{color:#1a202c;color:var(--color-text)}.textarea{border:2px solid #e2e8f0;border:2px solid var(--color-border);border-radius:8px;font-family:inherit;font-size:1rem;padding:1rem;transition:all .2s ease;width:100%}.textarea:focus{border-color:#2b6cb0;border-color:var(--color-primary);box-shadow:0 0 0 3px #2b6cb01a;outline:none}.textarea::placeholder{color:#718096;color:var(--color-text-light)}.loading-spinner{border:3px solid #ffffff4d}@media (max-width:768px){.translate-grid{grid-template-columns:1fr}.translate-controls{align-items:stretch}.feedback-controls,.translate-actions,.translate-controls{flex-direction:column}.feedback-controls{align-items:flex-start;gap:1rem}.vocabulary-suggestions{gap:.5rem}.vocab-suggestion-item{flex-basis:calc(50% - 0.25rem);flex-grow:1;flex-shrink:1;min-width:120px}.card{padding:1rem}}@media (max-width:480px){.vocab-suggestion-item{flex:1 1 100%}.translate h1{font-size:1.5rem}}.vocabulary{margin:0 auto;max-width:1200px}.page-description{color:var(--color-text-secondary);font-size:1.125rem;margin-bottom:2rem}.vocabulary-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.card-description{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:1.5rem}.vocabulary-list-section{margin-top:2rem}.vocabulary-list-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.vocabulary-list-header h3{margin:0}.search-box,.vocabulary-list-header h3{align-items:center;display:flex;gap:.5rem}.search-box{background:var(--color-background);border:2px solid var(--color-border);border-radius:8px;min-width:250px;padding:.5rem 1rem}.search-box input{background:none;border:none;flex:1 1;padding:0}.search-box input:focus{box-shadow:none;outline:none}.vocabulary-table{overflow-x:auto}.vocabulary-table table{border-collapse:collapse;width:100%}.vocabulary-table th{background:var(--color-background);border-bottom:2px solid var(--color-border);color:var(--color-text-primary);font-weight:600;padding:1rem;text-align:left}.vocabulary-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);padding:1rem}.vocabulary-table tr:hover{background:var(--color-background)}@media (max-width:768px){.vocabulary-grid{grid-template-columns:1fr}.vocabulary-list-header{align-items:stretch;flex-direction:column}.search-box{min-width:auto}.vocabulary-table{font-size:.875rem}.vocabulary-table td,.vocabulary-table th{padding:.75rem}}.audio-tools{margin:0 auto;max-width:1200px}.audio-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.audio-header,.audio-panel{display:flex;flex-direction:column}.audio-header{align-items:center;margin-bottom:1.5rem;text-align:center}.audio-icon-wrapper{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin-bottom:1rem;width:80px}.audio-icon-wrapper.tts{background:linear-gradient(135deg,#2b6cb01a,#2b6cb033);color:var(--color-primary)}.audio-icon-wrapper.stt{background:linear-gradient(135deg,#f6ad551a,#f6ad5533);color:var(--color-accent)}.audio-header h2{font-size:1.5rem;margin:0}.recording-area{align-items:center;background:var(--color-background);border-radius:12px;display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0;padding:2rem}.recording-indicator{color:var(--color-accent);height:100px;justify-content:center;position:relative;width:100px}.pulse-ring{border:3px solid var(--color-accent);border-radius:50%;height:100%;opacity:.6;position:absolute;width:100%}.recording-area p{color:var(--color-text-secondary);margin:0}.audio-controls{display:flex;gap:1rem;justify-content:center}.info-section{margin-top:2rem}.features-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.feature-item{align-items:center;background:var(--color-background);border-radius:8px;display:flex;gap:1rem;padding:.75rem}@media (max-width:768px){.audio-grid{grid-template-columns:1fr}}@media (max-width:480px){.audio-icon-wrapper{height:60px;width:60px}.audio-icon-wrapper.stt svg,.audio-icon-wrapper.tts svg{height:24px;width:24px}.recording-indicator{height:80px;width:80px}}.feedback{margin:0 auto;max-width:1200px}.feedback-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1.5fr 1fr}.feedback-form h3{align-items:center;display:flex;gap:.5rem;margin-bottom:1.5rem}.star-rating{gap:.5rem;margin-top:.5rem}.star{background:none;border:none;color:var(--color-border);cursor:pointer;padding:0;transition:all .2s}.star:hover{transform:scale(1.1)}.rating-text,.star.active{color:var(--color-accent)}.rating-text{font-weight:600;margin-top:.5rem}.feedback-info{display:flex;flex-direction:column;gap:2rem}.feedback-benefits{color:var(--color-text-secondary);line-height:1.8;margin-top:1rem;padding-left:1.5rem}.feedback-benefits li{margin-bottom:.5rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-top:1rem}.stat-item{background:var(--color-background);border-radius:8px;padding:1rem;text-align:center}.stat-value{font-size:2rem;font-weight:700}.stat-label{font-size:.75rem;margin-top:.25rem}@media (max-width:768px){.feedback-grid,.stats-grid{grid-template-columns:1fr}.star-rating{justify-content:center}}.dashboard{margin:0 auto;max-width:1400px}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.metric-card{align-items:flex-start;display:flex;gap:1rem}.metric-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.metric-icon.primary{background:#2b6cb01a;color:var(--color-primary)}.metric-icon.secondary{background:#38a1691a;color:var(--color-secondary)}.metric-icon.accent{background:#f6ad551a;color:var(--color-accent)}.metric-content{flex:1 1}.metric-value{color:var(--color-text-primary);font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.metric-label{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:.5rem}.metric-change{align-items:center;display:flex;font-size:.875rem;font-weight:500;gap:.25rem}.metric-change.positive{color:var(--color-secondary)}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.chart-card h3{margin-bottom:1.5rem}.chart-placeholder{background:var(--color-background);border-radius:8px;height:300px;padding:2rem}.chart-bars,.chart-placeholder{align-items:flex-end;display:flex}.chart-bars{gap:1rem;height:100%;justify-content:space-around;width:100%}.chart-bar{background:linear-gradient(to top,var(--color-primary),var(--color-secondary));border-radius:4px 4px 0 0;flex:1 1;min-height:20px;position:relative;transition:all .3s}.chart-bar:hover{opacity:.8;transform:translateY(-4px)}.bar-label{bottom:-1.5rem;color:var(--color-text-secondary);font-size:.75rem;left:50%;position:absolute;transform:translateX(-50%);white-space:nowrap}.domain-list{display:flex;flex-direction:column;gap:1.5rem}.domain-item{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:100px 1fr 60px}.domain-name{color:var(--color-text-primary);font-weight:500}.progress-bar{background:var(--color-border);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(to right,var(--color-primary),var(--color-secondary));border-radius:4px;height:100%;transition:width .3s}.domain-score{color:var(--color-primary);font-weight:600;text-align:right}.table-container{overflow-x:auto}.translations-table{border-collapse:collapse;margin-top:1rem;width:100%}.translations-table th{background:var(--color-background);border-bottom:2px solid var(--color-border);color:var(--color-text-primary);font-weight:600;padding:1rem;text-align:left}.translations-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);padding:1rem}.translations-table tr:hover{background:var(--color-background)}.quality-score{border-radius:4px;font-weight:600;padding:.25rem .5rem}.quality-score.high{background:#48bb781a;color:var(--color-success)}.quality-score.medium{background:#f6ad551a;color:var(--color-accent)}@media (max-width:768px){.dashboard-grid,.metrics-grid{grid-template-columns:1fr}.domain-item{gap:.5rem;grid-template-columns:80px 1fr 50px}.chart-placeholder{padding:1rem}.translations-table{font-size:.875rem}.translations-table td,.translations-table th{padding:.75rem}}.profile{margin:0 auto;max-width:1200px}.profile-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:350px 1fr}.profile-card{text-align:center}.profile-card,.profile-header{align-items:center;display:flex;flex-direction:column}.profile-header{border-bottom:1px solid var(--color-border);margin-bottom:1.5rem;padding-bottom:1.5rem;width:100%}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:50%;color:#fff;display:flex;height:120px;justify-content:center;margin-bottom:1rem;width:120px}.profile-header h2{font-size:1.75rem;margin:0}.profile-role{color:var(--color-text-secondary);margin-top:.25rem}.profile-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;width:100%}.info-item{align-items:center;background:var(--color-background);border-radius:8px;color:var(--color-text-secondary);display:flex;gap:.75rem;padding:.75rem;text-align:left}.profile-settings{display:flex;flex-direction:column;gap:2rem}.profile-settings h3{align-items:center;display:flex;gap:.5rem;margin-bottom:1.5rem}.stats-list{display:flex;flex-direction:column;gap:1rem}.stat-row{align-items:center;background:var(--color-background);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.stat-label{color:var(--color-text-secondary)}.stat-value{color:var(--color-primary);font-size:1.125rem;font-weight:600}@media (max-width:768px){.profile-grid{grid-template-columns:1fr}.profile-avatar{height:100px;width:100px}}.about{margin:0 auto;max-width:1000px}.about-hero{margin-bottom:3rem;text-align:center}.about-logo{color:var(--color-primary);margin-bottom:1rem}.about-hero h1{font-size:2.5rem;margin-bottom:1rem}.about-tagline{color:var(--color-text-secondary);font-size:1.25rem;margin:0 auto;max-width:700px}.about-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.about-card{padding:2rem;text-align:center}.about-icon-wrapper{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.about-icon-wrapper.mission{background:linear-gradient(135deg,#2b6cb01a,#2b6cb033);color:var(--color-primary)}.about-icon-wrapper.vision{background:linear-gradient(135deg,#38a1691a,#38a16933);color:var(--color-secondary)}.about-icon-wrapper.values{background:linear-gradient(135deg,#f6ad551a,#f6ad5533);color:var(--color-accent)}.about-card h3{color:var(--color-text-primary);margin-bottom:1rem}.about-card p{color:var(--color-text-secondary);line-height:1.7}.about-section{margin-bottom:2rem}.about-section h2{align-items:center;display:flex;gap:.75rem;margin-bottom:1.5rem}.about-section p{color:var(--color-text-secondary);line-height:1.8;margin-bottom:1rem}.features-list-about{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}.feature-item-about{align-items:flex-start;background:var(--color-background);border-radius:8px;display:flex;gap:1rem;padding:1rem}.feature-bullet{background:var(--color-primary);border-radius:50%;flex-shrink:0;height:8px;margin-top:.5rem;width:8px}.feature-item-about strong{color:var(--color-text-primary)}.partners{text-align:center}.partners-description{margin-bottom:2rem;text-align:center}.partners-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:2rem}.partner-placeholder{align-items:center;background:var(--color-background);border:2px dashed var(--color-border);border-radius:8px;color:var(--color-text-secondary);display:flex;font-size:.875rem;height:100px;justify-content:center}.contact{background:linear-gradient(135deg,#2b6cb00d,#38a1690d);text-align:center}.contact-info{background:var(--color-card-bg);border-radius:8px;display:inline-block;margin-top:1.5rem;padding:1.5rem;text-align:left}.contact-info p{margin-bottom:.5rem}.contact-info p:last-child{margin-bottom:0}@media (max-width:768px){.about-hero h1{font-size:2rem}.about-tagline{font-size:1rem}.about-grid{grid-template-columns:1fr}.partners-grid{grid-template-columns:repeat(2,1fr)}}:root{--color-danger:#dc2626}.speech-translate{margin:0 auto;max-width:1200px;padding:2rem}.speech-translate h1{color:#1a202c;color:var(--color-text);font-size:2.5rem;margin-bottom:2rem}.speech-container{grid-gap:2rem;display:grid;gap:2rem}.speech-controls{align-items:end;display:flex;flex-wrap:wrap;gap:1rem}.speech-controls .input-group{flex:1 1;min-width:200px}.card h3{font-size:1.25rem}.audio-input-section{background:linear-gradient(135deg,#2b6cb005,#38a16905)}.input-options{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:1fr auto 1fr;margin-top:1.5rem}.upload-area2{display:flex;justify-content:center}.file-input{display:none}.upload-label{align-items:center;background:#fff;background:var(--color-card);border:2px dashed #e2e8f0;border:2px dashed var(--color-border);border-radius:12px;color:#1a202c;color:var(--color-text);cursor:pointer;display:flex;flex-direction:column;gap:.75rem;padding:2rem 1.5rem;text-align:center;transition:all .3s ease;width:100%}.upload-label:hover{background:#2b6cb00d;border-color:#2b6cb0;border-color:var(--color-primary);transform:translateY(-2px)}.upload-label svg{color:#2b6cb0;color:var(--color-primary)}.upload-hint{font-size:.75rem}.input-divider{color:#718096;color:var(--color-text-light);font-size:.875rem;font-weight:600;text-align:center}.record-area{gap:1rem}.record-area,.record-btn{align-items:center;display:flex;flex-direction:column}.record-btn{background:#fff;background:var(--color-card);border:2px solid #e2e8f0;border:2px solid var(--color-border);border-radius:12px;color:#1a202c;color:var(--color-text);cursor:pointer;gap:.75rem;padding:2rem 1.5rem;transition:all .3s ease;width:100%}.record-btn:hover{background:#f6ad550d;border-color:#f6ad55;border-color:var(--color-accent);transform:translateY(-2px)}.record-btn svg{color:#f6ad55;color:var(--color-accent)}.record-btn.recording{animation:recordingPulse 2s ease-in-out infinite;background:#dc26260d;border-color:#dc2626;border-color:var(--color-danger)}.record-btn.recording svg{color:#dc2626;color:var(--color-danger)}@keyframes recordingPulse{0%,to{box-shadow:0 0 0 0 #dc262666}50%{box-shadow:0 0 0 10px #dc262600}}.recording-indicator{align-items:center;color:#dc2626;color:var(--color-danger);display:flex;font-weight:600;gap:.75rem}.recording-pulse{animation:pulse 1.5s ease-in-out infinite;background:#dc2626;background:var(--color-danger);border-radius:50%;height:12px;width:12px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.recording-time{font-family:Courier New,monospace;font-size:1.125rem}.audio-status{align-items:center;background:#2b6cb00d;border:1px solid #2b6cb01a;border-radius:8px;display:flex;gap:.75rem;margin-top:1rem;padding:1rem}.audio-status svg{color:#2b6cb0;color:var(--color-primary);flex-shrink:0}.status-text{color:#1a202c;color:var(--color-text);flex:1 1;font-weight:500}.remove-btn{align-items:center;background:none;border:none;border-radius:4px;color:#718096;color:var(--color-text-light);cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:all .2s ease}.remove-btn:hover{background:#dc26261a;color:#dc2626;color:var(--color-danger)}.speech-actions{display:flex;gap:1rem;margin-top:1rem}.btn-secondary:hover{background:#fff;background:var(--color-card);border-color:#2b6cb0;border-color:var(--color-primary);color:#2b6cb0;color:var(--color-primary);transform:translateY(-2px)}.ai-status{border:1px solid}.ai-status.processing{border-color:#f6ad5533}.ai-status.success{background:#38a1690d;border-color:#38a1691a;color:var(--color-secondary)}.badge{border-radius:12px}.badge-success{background:#38a1691a;color:#38a169;color:var(--color-secondary)}.audio-output-section{background:linear-gradient(135deg,#2b6cb005,#f6ad5505)}.audio-player-container{align-items:center;background:#f9fafb;background:var(--color-background);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;display:flex;gap:1.5rem;padding:1.5rem}.play-btn{align-items:center;background:#2b6cb0;background:var(--color-primary);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:64px;justify-content:center;transition:all .3s ease;width:64px}.play-btn:hover{background:#1e4a7a;box-shadow:0 4px 16px #2b6cb066;transform:scale(1.1)}.play-btn:active{transform:scale(.95)}.player-info{flex:1 1}.player-label{color:#1a202c;color:var(--color-text);font-weight:500}.transcript-section{background:linear-gradient(135deg,#38a16905,#2b6cb005)}.transcript-text{background:#f9fafb;background:var(--color-background);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:8px;color:#1a202c;color:var(--color-text);font-size:1rem;line-height:1.8;min-height:100px;padding:1.5rem}.feedback-section h3{font-size:1rem}.feedback-controls{align-items:center;gap:2rem}.thumbs-feedback{display:flex;gap:.5rem}.feedback-btn{padding:.5rem 1rem}.star-rating{display:flex;gap:.25rem}.star-btn{background:none;border:none;color:#e2e8f0;color:var(--color-border);cursor:pointer;padding:.25rem;transition:all .2s ease}.star-btn:hover{transform:scale(1.15)}.star-btn.filled,.star-btn:hover{color:#f6ad55;color:var(--color-accent)}.star-btn svg{fill:currentColor}.vocabulary-section h3{font-size:1.125rem}.vocabulary-section h4{color:#1a202c;color:var(--color-text);font-size:1rem;font-weight:600;margin-bottom:1rem;margin-top:1.5rem}.vocabulary-description{color:#718096;color:var(--color-text-light);font-size:.875rem;margin-bottom:1rem}.vocabulary-suggestions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.vocab-suggestion-item{align-items:center;background:#f9fafb;background:var(--color-background);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:8px;display:flex;gap:.5rem;padding:.5rem .75rem;transition:all .2s ease}.vocab-suggestion-item:hover{border-color:#2b6cb0;border-color:var(--color-primary);box-shadow:0 2px 4px #2b6cb01a}.vocab-word{color:#1a202c;color:var(--color-text);font-size:.9rem;font-weight:500}.vocab-add-btn{align-items:center;background:#2b6cb0;background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all .2s ease;width:24px}.vocab-add-btn:hover:not(:disabled){background:#1e4a7a;transform:scale(1.1)}.vocab-add-btn:disabled{cursor:default}.vocab-add-btn.added,.vocab-add-btn:disabled{background:#38a169;background:var(--color-secondary)}.vocab-add-btn.added{animation:successPulse .4s ease}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.vocabulary-list{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);padding-top:1rem}.vocab-items{grid-gap:.75rem;display:grid;gap:.75rem}.vocab-item{align-items:center;background:#f9fafb;background:var(--color-background);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:all .2s ease}.vocab-item:hover{border-color:#2b6cb0;border-color:var(--color-primary);box-shadow:0 2px 4px #2b6cb01a}.vocab-item-content{display:flex;flex-direction:column;gap:.25rem}.vocab-item-word{color:#1a202c;color:var(--color-text);font-size:1rem;font-weight:600}.vocab-item-lang{font-size:.75rem}.vocab-item-lang,.vocab-remove-btn{color:#718096;color:var(--color-text-light)}.vocab-remove-btn{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:28px;justify-content:center;line-height:1;transition:all .2s ease;width:28px}.vocab-remove-btn:hover{background:#dc26261a;color:#dc2626;color:var(--color-danger)}.loading-spinner{border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@media (max-width:768px){.speech-translate{padding:1rem}.speech-translate h1{font-size:1.75rem;margin-bottom:1.5rem}.speech-controls{align-items:stretch;flex-direction:column}.input-options{gap:1rem;grid-template-columns:1fr}.input-divider{display:none}.record-btn,.upload-label{padding:1.5rem 1rem}.feedback-controls,.speech-actions{flex-direction:column}.feedback-controls{align-items:flex-start;gap:1rem}.vocabulary-suggestions{gap:.5rem}.vocab-suggestion-item{flex-basis:calc(50% - 0.25rem);flex-grow:1;flex-shrink:1;min-width:120px}.card{padding:1rem}.audio-player-container{flex-direction:column;text-align:center}.play-btn{height:56px;width:56px}}@media (max-width:480px){.speech-translate h1{font-size:1.5rem}.vocab-suggestion-item{flex:1 1 100%}.card h3{font-size:1.125rem}.transcript-text{font-size:.9rem;padding:1rem}}:root{--color-primary:#2b6cb0;--color-secondary:#38a169;--color-accent:#f6ad55;--color-background:#f9fafb;--color-card:#fff;--color-text:#1a202c;--color-text-light:#718096;--color-border:#e2e8f0;--color-error:#e53e3e;--color-success:#38a169}.document-translate{margin:0 auto;max-width:1200px;padding:2rem}.document-translate h1{color:#1a202c;color:var(--color-text);font-size:2rem;font-weight:700;margin-bottom:2rem}.translate-container{grid-gap:2rem;display:grid;gap:2rem}.translate-controls{align-items:end;display:flex;flex-wrap:wrap;gap:1rem}.translate-controls .input-group{flex:1 1;min-width:180px}.input-group label{font-size:.875rem;font-weight:600}.input-group label,.select{color:#1a202c;color:var(--color-text)}.select{background:#fff;background:var(--color-card);border:2px solid #e2e8f0;border:2px solid var(--color-border);border-radius:8px;font-size:1rem;padding:.75rem;transition:all .2s ease;width:100%}.select:focus{border-color:#2b6cb0;border-color:var(--color-primary);box-shadow:0 0 0 3px #2b6cb01a;outline:none}.select:disabled{background:#f9fafb;background:var(--color-background);cursor:not-allowed;opacity:.6}.card{background:#fff;background:var(--color-card);border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.card h3{color:#1a202c;color:var(--color-text);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.upload-card{margin-top:1rem}.upload-area{background:#f9fafb;background:var(--color-background);border:2px dashed #e2e8f0;border:2px dashed var(--color-border);border-radius:12px;padding:3rem 2rem;text-align:center;transition:all .3s ease}.upload-area.dragging{background:#2b6cb00d;border-color:#2b6cb0;border-color:var(--color-primary);transform:scale(1.02)}.upload-area.has-file{background:#fff;background:var(--color-card);padding:1.5rem}.upload-icon{color:#718096;color:var(--color-text-light);margin-bottom:1rem}.upload-text{color:#1a202c;color:var(--color-text);font-size:1.125rem;font-weight:500;margin-bottom:.5rem}.upload-subtext{color:#718096;color:var(--color-text-light);margin:.5rem 0}.upload-button{align-items:center;background:#2b6cb0;background:var(--color-primary);border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;margin:.5rem 0;padding:.75rem 1.5rem;transition:all .2s ease}.upload-button:hover{background:#1e4a7a;box-shadow:0 4px 12px #2b6cb04d;transform:translateY(-2px)}.upload-hint{color:#718096;color:var(--color-text-light);font-size:.875rem;margin-top:1rem}.file-preview{align-items:center;background:#f9fafb;background:var(--color-background);border-radius:8px;display:flex;gap:1rem;padding:1rem}.file-icon{flex-shrink:0;font-size:2.5rem}.file-info{flex:1 1;text-align:left}.file-name{color:#1a202c;color:var(--color-text);font-weight:600;margin-bottom:.25rem;word-break:break-word}.file-size{font-size:.875rem}.file-size,.remove-file-btn{color:#718096;color:var(--color-text-light)}.remove-file-btn{background:none;border:none;border-radius:6px;cursor:pointer;flex-shrink:0;padding:.5rem;transition:all .2s ease}.remove-file-btn:hover{background:#e53e3e1a;color:#e53e3e;color:var(--color-error)}.remove-file-btn:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#e53e3e1a;border:1px solid #e53e3e4d;border-radius:8px;color:#e53e3e;color:var(--color-error);font-weight:500;padding:1rem}.translate-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn{display:flex;transition:all .2s ease}.btn-primary{background:#2b6cb0;background:var(--color-primary)}.btn-primary:hover:not(:disabled){background:#1e4a7a;box-shadow:0 4px 12px #2b6cb04d;transform:translateY(-2px)}.btn-primary:disabled{background:#718096;background:var(--color-text-light);cursor:not-allowed;opacity:.6}.btn-secondary{background:#f9fafb;background:var(--color-background);border:2px solid #e2e8f0;border:2px solid var(--color-border);color:#1a202c;color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#fff;background:var(--color-card);border-color:#2b6cb0;border-color:var(--color-primary);color:#2b6cb0;color:var(--color-primary);transform:translateY(-2px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.btn-download{background:#38a169;background:var(--color-secondary);color:#fff;font-size:1.125rem;justify-content:center;padding:1rem 1.5rem;width:100%}.btn-download:hover{background:#2f855a;box-shadow:0 4px 12px #38a1694d;transform:translateY(-2px)}.ai-status{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:.75rem;margin-top:1rem;padding:1rem}.ai-status.processing{background:#f6ad551a;border:1px solid #f6ad5533;color:#f6ad55;color:var(--color-accent)}.ai-status.success{background:#38a1691a;border:1px solid #38a16933;color:#38a169;color:var(--color-success)}.download-card{margin-top:1.5rem}.download-info{color:#718096;color:var(--color-text-light);font-size:.875rem;margin-top:.75rem;text-align:center}.feedback-section{margin-top:1.5rem}.feedback-controls{display:flex;gap:1rem;margin-top:1rem}.feedback-btn{align-items:center;background:#f9fafb;background:var(--color-background);border:2px solid #e2e8f0;border:2px solid var(--color-border);border-radius:8px;color:#718096;color:var(--color-text-light);cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s ease}.feedback-btn:hover{background:#fff;background:var(--color-card);color:#2b6cb0;color:var(--color-primary);transform:translateY(-2px)}.feedback-btn.active,.feedback-btn:hover{border-color:#2b6cb0;border-color:var(--color-primary)}.feedback-btn.active{background:#2b6cb0;background:var(--color-primary);color:#fff}.feedback-thanks{color:#38a169;color:var(--color-success);font-weight:500;margin-top:1rem;text-align:center}.loading-spinner{animation:spin .8s linear infinite}.spinning{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.fade-in{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.document-translate{padding:1rem}.document-translate h1{font-size:1.5rem}.translate-controls{align-items:stretch;flex-direction:column}.translate-controls .input-group{min-width:100%}.translate-actions{flex-direction:column}.upload-area{padding:2rem 1rem}.feedback-controls{flex-direction:column}.card{padding:1rem}}@media (max-width:480px){.document-translate h1{font-size:1.25rem}.upload-text{font-size:1rem}.file-preview{flex-direction:column}.file-info,.file-preview{text-align:center}}.app-container{display:flex;flex-direction:column;min-height:100vh}.content-wrapper,.main-layout{display:flex;flex:1 1}.content-wrapper{flex-direction:column}.page-content{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}@media (max-width:768px){.page-content{padding:1rem}}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s}.btn-primary{background:linear-gradient(135deg,var(--color-primary),#1e4e89);color:#fff;overflow:hidden;position:relative}.btn-primary:before{background:linear-gradient(45deg,var(--color-accent),var(--color-secondary),var(--color-primary));border-radius:10px;bottom:-2px;content:"";left:-2px;opacity:0;position:absolute;right:-2px;top:-2px;transition:opacity .3s;z-index:-1}.btn-primary:hover:before{animation:pulse 2s ease-in-out infinite;opacity:1}.btn-primary:hover{box-shadow:0 6px 20px #2b6cb066;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-secondary:hover{background:var(--color-primary);color:#fff}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:#e69944;transform:translateY(-2px)}.input-group{margin-bottom:1.5rem}.input-group label{color:var(--color-text-primary);display:block;font-weight:500;margin-bottom:.5rem}.input,.select,.textarea{background:var(--color-card-bg);border:2px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2b6cb01a;outline:none}.textarea{min-height:120px;resize:vertical}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);margin-bottom:1rem}h1{font-size:2.5rem;font-weight:700}h2{font-size:2rem}h2,h3{font-weight:600}h3{font-size:1.5rem}@media (max-width:768px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}.grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.badge{border-radius:20px;display:inline-block;font-size:.875rem;font-weight:600;padding:.25rem .75rem}.badge-primary{background:#2b6cb01a;color:var(--color-primary)}.badge-success{background:#48bb781a;color:var(--color-success)}.badge-warning{background:#f6ad551a;color:var(--color-accent)}
/*# sourceMappingURL=main.171a50b6.css.map*/