.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:#0f1419;position:relative}.auth-container:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(16,185,129,.04) 0%,transparent 50%);pointer-events:none;z-index:0}.auth-card{background:#1a1f2e;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:32px 24px;width:100%;max-width:420px;box-shadow:0 4px 24px #0006;position:relative;z-index:1}.auth-card h1{margin:0 0 8px;font-size:1.75rem;color:#fff;text-align:center;font-weight:600;letter-spacing:-.02em}.auth-subtitle{text-align:center;color:#94a3b8;margin:0 0 32px;font-size:.9375rem;font-weight:400}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-weight:500;color:#e2e8f0;font-size:.875rem}.form-group input{padding:12px 14px;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9375rem;background:#ffffff08;color:#fff;transition:all .2s ease}.form-group input::placeholder{color:#64748b}.form-group input:focus{outline:none;border-color:#3b82f6;background:#3b82f60d}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-hint{font-size:.8125rem;color:#64748b;margin:0;line-height:1.4}.code-input{text-align:center;font-size:1.5rem;letter-spacing:.5em;font-weight:600;font-family:SF Mono,Monaco,Courier New,monospace}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d;margin-top:8px}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-actions{margin-top:16px;text-align:center}.btn-text{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.875rem;text-decoration:none;padding:8px;font-weight:500;transition:color .2s ease}.btn-text:hover:not(:disabled){color:#60a5fa}.btn-text:disabled{color:#475569;cursor:not-allowed}.auth-link{text-align:center;margin-top:24px;color:#64748b;font-size:.875rem;line-height:1.5}.auth-link a{color:#3b82f6;text-decoration:none;font-weight:500}.auth-link a:hover{color:#60a5fa}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;background:#0f1419}.loading-container p{color:#94a3b8;font-size:.9375rem}@media(max-width:480px){.auth-card{padding:24px 20px}.auth-card h1{font-size:1.5rem}.auth-subtitle{font-size:.875rem;margin-bottom:24px}.form-group input{font-size:16px}.code-input{font-size:1.25rem;letter-spacing:.4em}}@media(min-width:769px){.auth-container{padding:32px}.auth-card{padding:40px}.auth-card h1{font-size:2rem}}.admin-page{width:100%;max-width:1400px;margin:0 auto;padding:20px;min-height:100vh}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;background:#1a1f2e;padding:24px;border-radius:16px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08)}.admin-header .header-left h1{font-size:2rem;color:#fff;margin:0 0 4px}.admin-subtitle{font-size:.9rem;color:#94a3b8;margin:0}.admin-header .header-actions{display:flex;gap:12px;align-items:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#1a1f2e;padding:24px;border-radius:12px;box-shadow:0 2px 12px #0000004d;border:1px solid rgba(255,255,255,.08);text-align:center}.stat-card h3{font-size:.9rem;color:#94a3b8;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2.5rem;font-weight:700;color:#3b82f6;margin:0}.users-section{background:#1a1f2e;padding:24px;border-radius:16px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08)}.users-section h2{font-size:1.5rem;color:#fff;margin:0 0 20px}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:.9rem}.users-table thead th{background:#ffffff08;padding:12px;text-align:left;font-weight:600;color:#fff;border-bottom:2px solid rgba(255,255,255,.1)}.users-table tbody tr{border-bottom:1px solid rgba(255,255,255,.05);transition:background-color .2s}.users-table tbody tr:hover{background-color:#ffffff08}.users-table tbody tr.editing{background-color:#3b82f61a}.users-table tbody td{padding:12px;vertical-align:middle;color:#e2e8f0}.user-email{font-weight:600;color:#fff}.user-id{font-size:.75rem;color:#64748b;font-family:monospace}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-user{background:#e3f2fd;color:#1976d2}.badge-admin{background:#fce4ec;color:#c2185b}.badge-free{background:#f3e5f5;color:#7b1fa2}.badge-pro{background:#fff3e0;color:#ef6c00}.badge-enterprise{background:#e8f5e9;color:#388e3c}.badge-active{background:#e8f5e9;color:#2e7d32}.badge-suspended{background:#ffebee;color:#c62828}.usage{font-size:.85rem;color:#94a3b8;margin-bottom:4px}.usage-bar{width:100%;height:6px;background:#ffffff0d;border-radius:3px;overflow:hidden}.usage-fill{height:100%;background:#3b82f6;transition:width .3s}.users-table select{padding:6px 12px;border:2px solid rgba(255,255,255,.1);border-radius:6px;font-size:.85rem;background:#ffffff08;color:#fff;cursor:pointer}.users-table select:focus{outline:none;border-color:#3b82f6;background:#ffffff0d}.action-buttons{display:flex;gap:8px}.btn-small{padding:6px 12px;font-size:.85rem}.loading{text-align:center;padding:60px 20px;color:#94a3b8;font-size:1.2rem}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-value{font-size:2rem}}@media(max-width:768px){.admin-page{padding:10px}.admin-header{flex-direction:column;gap:16px;align-items:flex-start;padding:16px}.admin-header .header-left h1{font-size:1.5rem}.admin-subtitle{font-size:.85rem}.admin-header .header-actions{width:100%;flex-wrap:wrap}.admin-header .header-actions .btn,.admin-header .header-actions .logout-btn{font-size:.85rem;padding:8px 14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-card h3{font-size:.8rem}.stat-value{font-size:2rem}.users-section{padding:16px}.users-section h2{font-size:1.3rem}.users-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table{min-width:900px;font-size:.85rem}.users-table thead th{padding:10px 8px;font-size:.8rem}.users-table tbody td{padding:10px 8px}.badge{font-size:.7rem;padding:3px 10px}.action-buttons{flex-direction:column;gap:6px}.btn-small{width:100%;padding:8px 10px;font-size:.8rem}}@media(max-width:480px){.admin-page{padding:5px}.admin-header{padding:12px}.admin-header .header-left h1{font-size:1.3rem}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-card{padding:12px}.stat-value{font-size:1.8rem}.users-section{padding:12px}.users-section h2{font-size:1.2rem}}.tabs{display:flex;gap:8px;margin-bottom:24px}.tab{padding:12px 24px;border:none;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;color:#94a3b8;transition:all .2s;box-shadow:0 2px 8px #0003}.tab:hover{background:#ffffff0d;color:#fff}.tab.active{background:#3b82f6;color:#fff;box-shadow:0 4px 16px #3b82f666;border-color:#3b82f6}.transcriptions-section{background:#1a1f2e;padding:24px;border-radius:16px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08)}.transcriptions-section h2{font-size:1.5rem;color:#fff;margin:0 0 24px}.transcription-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:16px;transition:all .2s}.transcription-card:hover{background:#ffffff0d;box-shadow:0 4px 16px #0000004d;border-color:#3b82f6}.transcription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.transcription-header .user-info{display:flex;flex-direction:column;gap:4px}.transcription-header .user-info strong{color:#fff;font-size:.95rem}.transcription-header .user-id{font-size:.75rem;color:#64748b;font-family:Courier New,monospace}.transcription-meta{display:flex;gap:16px;align-items:center;font-size:.85rem;color:#94a3b8}.transcription-meta .timestamp{color:#94a3b8}.transcription-meta .duration{background:#e0e7ff;color:#4338ca;padding:4px 8px;border-radius:4px;font-weight:500}.transcription-meta .confidence{background:#dcfce7;color:#166534;padding:4px 8px;border-radius:4px;font-weight:500}.transcription-text{background:#ffffff08;padding:16px;border-radius:8px;border-left:4px solid #3b82f6;line-height:1.6;color:#e2e8f0;font-size:.95rem;white-space:pre-wrap}.transcriptions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.transcriptions-header h2{margin:0}.meta-badge{display:inline-block;background:#f3e8ff;color:#6b21a8;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;margin-left:8px}.no-meta-prompt{background:#fef3c7;color:#92400e;padding:12px;border-radius:6px;font-size:.85rem;margin-top:12px;text-align:center}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{margin:0}.create-user-btn{padding:10px 20px;font-size:.95rem}.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:#1a1f2e;padding:32px;border-radius:16px;max-width:500px;width:90%;box-shadow:0 20px 60px #000c;border:1px solid rgba(255,255,255,.1)}.modal-content h2{margin:0 0 8px;color:#fff}.modal-description{color:#94a3b8;margin:0 0 24px;font-size:.95rem}.modal-content .form-group{margin-bottom:24px}.modal-content .form-group label{display:block;margin-bottom:8px;color:#fff;font-weight:600}.modal-content .form-group input{width:100%;padding:12px;border:2px solid rgba(255,255,255,.1);border-radius:8px;font-size:1rem;transition:border-color .2s;background:#ffffff08;color:#fff}.modal-content .form-group input:focus{outline:none;border-color:#3b82f6;background:#ffffff0d}.modal-content .form-group input:disabled{background:#ffffff05;cursor:not-allowed;opacity:.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-actions .btn{padding:10px 24px}.settings-page{width:100%;max-width:800px;margin:0 auto;padding:20px}.settings-card{background:#1a1f2e;border-radius:16px;padding:40px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08)}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid rgba(255,255,255,.08);gap:16px}.settings-header .header-left{flex:1}.settings-header h1{font-size:2.5rem;color:#fff;margin:0}.settings-header .header-right{display:flex;gap:12px;align-items:center}.back-link{color:#3b82f6;text-decoration:none;font-weight:600;font-size:1.05rem;padding:8px 16px;border-radius:8px;transition:all .2s;white-space:nowrap}.back-link:hover{background:#3b82f61a;color:#60a5fa}.settings-content{display:flex;flex-direction:column;gap:32px}.setting-section{padding:24px;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.setting-section h2{font-size:1.5rem;color:#fff;margin:0 0 12px}.setting-description{color:#94a3b8;line-height:1.6;margin-bottom:20px}.setting-description a{color:#3b82f6;text-decoration:none;font-weight:600}.setting-description a:hover{text-decoration:underline;color:#60a5fa}.status-badge{display:inline-block;padding:10px 16px;border-radius:8px;font-size:.95rem;font-weight:600;margin-bottom:20px}.status-configured{background:#e8f5e9;color:#2e7d32}.status-not-configured{background:#fff3e0;color:#e65100}.status-optional{background:#e3f2fd;color:#1565c0}.api-key-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#fff;font-size:1.05rem}.input-with-toggle{position:relative;display:flex;align-items:center}.api-key-input{flex:1;padding:12px 50px 12px 16px;font-size:1rem;border:2px solid rgba(255,255,255,.1);border-radius:8px;transition:border-color .2s;font-family:monospace;background:#ffffff08;color:#fff}.api-key-input:focus{outline:none;border-color:#3b82f6;background:#ffffff0d}.api-key-input:disabled{background:#ffffff05;cursor:not-allowed;opacity:.5}.toggle-visibility-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:1.2rem;padding:8px;transition:opacity .3s}.toggle-visibility-btn:hover{opacity:.7}.form-hint{color:#64748b;font-size:.85rem}.language-select{padding:12px 16px;font-size:1rem;border:2px solid rgba(255,255,255,.1);border-radius:8px;transition:border-color .2s;background:#ffffff08;color:#fff;cursor:pointer;min-height:44px;color-scheme:dark}.language-select option{background-color:#1a1f2e;color:#fff;padding:8px}.language-select:focus{outline:none;border-color:#3b82f6;background:#ffffff0d}.language-select:disabled{background:#ffffff05;cursor:not-allowed;opacity:.5}@media(max-width:480px){.language-select{font-size:.95rem;padding:10px 14px}}.btn{border:none;padding:16px 32px;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.settings-page{padding:10px}.settings-card{padding:20px;border-radius:12px}.settings-header{flex-direction:column;align-items:flex-start;gap:12px}.settings-header h1{font-size:1.8rem}.settings-header .header-right{width:100%;justify-content:space-between;flex-wrap:wrap}.back-link,.admin-link,.logout-btn{font-size:.9rem;padding:6px 12px}.setting-section{padding:16px}.setting-section h2{font-size:1.3rem}.setting-description{font-size:.95rem}.api-key-input{font-size:.9rem}.btn{padding:12px 24px;font-size:1rem}}@media(max-width:480px){.settings-card{padding:16px}.settings-header h1{font-size:1.5rem}.settings-header .header-right{gap:8px}.back-link,.admin-link,.logout-btn{font-size:.8rem;padding:8px 12px;min-height:44px;display:flex;align-items:center;justify-content:center}.setting-section{padding:12px}.setting-section h2{font-size:1.2rem}.setting-description{font-size:.9rem}.status-badge{font-size:.85rem;padding:8px 12px}.api-key-input{font-size:.85rem;padding:10px 40px 10px 12px}.btn{padding:12px 24px;font-size:.95rem;min-height:44px}}.project-card{padding:16px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:8px;margin-bottom:12px;transition:all .2s ease}.project-card.active{border-color:#3b82f64d;background:#3b82f60d}.project-card-header{display:flex;justify-content:space-between;align-items:center}.project-name{font-weight:600;color:#fff;font-size:1rem}.project-actions{display:flex;gap:8px}.project-action-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:4px 10px;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s}.project-action-btn:hover{background:#ffffff14;color:#e2e8f0}.project-delete-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.project-summary{margin-top:8px}.tech-badge{font-size:.8rem;color:#64748b;font-style:italic}.no-projects-text{color:#64748b;font-size:.9rem;font-style:italic;margin:12px 0}.project-form{margin-top:16px}.project-textarea{min-height:60px;resize:vertical;font-family:inherit}.project-form-actions{display:flex;gap:12px}.project-form-actions .btn{flex:1}@media(max-width:480px){.project-card-header{flex-direction:column;align-items:flex-start;gap:8px}.project-actions{width:100%;justify-content:flex-start}.project-form-actions{flex-direction:column}}*{box-sizing:border-box}.app{width:100%;min-height:100vh;background:#0f1419;position:relative;padding:16px}.app:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(16,185,129,.04) 0%,transparent 50%);pointer-events:none;z-index:0}.card{background:#1a1f2e;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px;max-width:600px;margin:0 auto;position:relative;z-index:1;box-shadow:0 4px 24px #0006}.header-with-link{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:16px}.header-left{flex:1}.header-right{display:flex;gap:12px;align-items:center}h1{font-size:1.75rem;color:#fff;margin:0;font-weight:600;letter-spacing:-.02em}.user-email{font-size:.875rem;color:#94a3b8;margin:4px 0 0;font-weight:400}.settings-link,.history-link,.admin-link{color:#e2e8f0;text-decoration:none;font-weight:500;font-size:.875rem;padding:8px 14px;border-radius:8px;transition:all .2s ease;white-space:nowrap;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.settings-link:hover,.history-link:hover,.admin-link:hover{background:#ffffff14;border-color:#ffffff26}.admin-link{background:#fbbf241a;border-color:#fbbf2433;color:#fbbf24}.admin-link:hover{background:#fbbf2426;border-color:#fbbf244d}.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s ease;white-space:nowrap}.logout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.subtitle{text-align:center;color:#94a3b8;margin:16px 0 24px;font-size:.9375rem;font-weight:400;line-height:1.5}.guide-section{background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:12px;padding:16px;margin-bottom:20px}.guide-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.guide-title{font-size:.875rem;font-weight:600;color:#93c5fd;text-transform:uppercase;letter-spacing:.05em}.guide-dismiss{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:#93c5fd;padding:4px 12px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.guide-dismiss:hover{background:#3b82f640}.guide-steps{display:flex;flex-direction:column;gap:8px}.guide-step{display:flex;align-items:flex-start;gap:10px}.guide-step-num{flex-shrink:0;width:22px;height:22px;background:#3b82f633;color:#93c5fd;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;margin-top:1px}.guide-step-text{color:#cbd5e1;font-size:.8125rem;line-height:1.5}.guide-reopen{display:block;margin:0 auto 16px;background:none;border:none;color:#64748b;font-size:.75rem;cursor:pointer;padding:4px 8px;transition:color .2s}.guide-reopen:hover{color:#94a3b8}.prompt-mode-selector{margin-bottom:24px;text-align:center}.prompt-mode-label{display:block;color:#94a3b8;font-size:.8125rem;font-weight:500;margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}.prompt-mode-buttons{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.prompt-mode-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:#94a3b8;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.prompt-mode-btn:hover{background:#ffffff0f;border-color:#ffffff26;color:#e2e8f0}.prompt-mode-btn.active{background:#3b82f626;border-color:#3b82f666;color:#93c5fd}.mode-icon{font-size:.875rem}.mode-label{font-size:.8125rem}.mode-description{color:#94a3b8;font-size:.8125rem;margin:10px 0 0;line-height:1.4;font-style:italic;min-height:1.4em}.active-project-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:8px;margin-top:10px;font-size:.8125rem}.badge-icon{font-size:.875rem}.badge-name{color:#93c5fd;font-weight:500}.badge-change{color:#64748b;text-decoration:none;font-size:.75rem;margin-left:4px}.badge-change:hover{color:#94a3b8}.pipeline-toggle{display:flex;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1);width:100%}.toggle-btn{flex:1;padding:8px 16px;background:#ffffff08;border:none;color:#94a3b8;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.toggle-btn:first-child{border-right:1px solid rgba(255,255,255,.1)}.toggle-btn.active{background:#3b82f626;color:#93c5fd}.toggle-btn:hover:not(.active){background:#ffffff0f}.pipeline-hint{font-size:.8rem;color:#64748b;text-align:center;margin:0;font-style:italic}.pipeline-steps-section{margin-top:16px}.pipeline-steps{margin-top:12px;display:flex;flex-direction:column;gap:8px}.pipeline-step{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:12px}.step-header{display:flex;gap:8px;align-items:center;margin-bottom:8px;font-size:.8125rem}.step-number{background:#3b82f626;color:#93c5fd;padding:2px 8px;border-radius:4px;font-weight:600}.step-name{color:#e2e8f0;font-weight:500}.step-duration{color:#64748b;margin-left:auto}.step-output{font-size:.8125rem;color:#94a3b8;line-height:1.5;white-space:pre-wrap;max-height:200px;overflow-y:auto}.meta-prompt-option{text-align:center;margin-bottom:20px}@media(max-width:480px){.prompt-mode-btn{padding:6px 10px;font-size:.75rem}.prompt-mode-buttons{gap:4px}}.checkbox-label{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:1rem;color:#555;padding:10px 16px;border-radius:8px;transition:background .2s}.checkbox-label:hover{background:#f7f7f7}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.checkbox-label span{-webkit-user-select:none;user-select:none}.record-control-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:40px auto;gap:20px}.record-button{position:relative;width:120px;height:120px;border-radius:50%;border:none;background:#3b82f6;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #3b82f666;outline:none;display:flex;align-items:center;justify-content:center}.record-button:hover:not(:disabled){background:#2563eb;box-shadow:0 6px 20px #3b82f680;transform:translateY(-2px)}.record-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 12px #3b82f666}.record-button:focus-visible{outline:2px solid #3b82f6;outline-offset:4px}.record-button:disabled{cursor:not-allowed;opacity:.5}.record-button.recording{background:#ef4444;box-shadow:0 4px 16px #ef444480;animation:pulse-recording 1.5s ease-in-out infinite}.record-button.recording:hover:not(:disabled){background:#dc2626;box-shadow:0 6px 20px #ef444499}@keyframes pulse-recording{0%,to{box-shadow:0 4px 16px #ef444480}50%{box-shadow:0 4px 24px #ef4444b3}}.record-button.processing{background:#8b5cf6;box-shadow:0 4px 16px #8b5cf666}.record-button-inner{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;z-index:2}.mic-icon-large{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.stop-icon{width:40px;height:40px;background:#fff;border-radius:6px;box-shadow:0 2px 8px #0003;transition:all .3s ease}.record-button.recording:hover .stop-icon{transform:scale(1.1)}.spinner-icon{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.audio-level-ring{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg);z-index:1;pointer-events:none}.record-state-label{display:flex;align-items:center;justify-content:center;gap:8px;min-height:32px;font-weight:600;letter-spacing:.5px}.state-text{font-size:1rem}.idle-text{color:#94a3b8;font-weight:500}.recording-text{color:#ef4444;font-size:1rem;font-family:SF Mono,Monaco,Courier New,monospace;font-weight:600;letter-spacing:.05em}.processing-text{color:#8b5cf6;font-size:.9375rem;font-weight:500}.recording-dot{width:12px;height:12px;background:#ef4444;border-radius:50%;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.controls{display:none}.btn{border:none;padding:16px 32px;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:600;display:flex;align-items:center;gap:8px}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-danger{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;animation:pulse 1.5s ease-in-out infinite}.btn-secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#e2e8f0;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .2s ease}.btn-secondary:hover{background:#ffffff14;border-color:#ffffff26}.btn-meta-prompt{background:#3b82f6;border:none;color:#fff;padding:12px 20px;font-size:.9375rem;font-weight:600;margin:0;width:100%;box-shadow:0 2px 8px #3b82f64d;transition:all .2s ease}.btn-meta-prompt:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.mic-indicator{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;padding:16px;margin:16px auto;max-width:500px;box-shadow:0 4px 12px #10b9814d}.mic-status{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#fff;font-weight:600}.mic-icon{font-size:1.2rem}.mic-label{font-size:.95rem}.audio-level-container{display:flex;align-items:center;gap:12px}.audio-level-bar{flex:1;height:24px;background:#fff3;border-radius:12px;overflow:hidden}.audio-level-fill{height:100%;background:linear-gradient(90deg,#34d399,#10b981);transition:width .1s ease-out;border-radius:12px}.audio-level-text{color:#fff;font-weight:600;font-size:.9rem;min-width:45px;text-align:right}.icon{font-size:1.3rem}.processing{display:flex;align-items:center;gap:12px;color:#667eea;font-size:1.1rem;font-weight:600}.spinner{width:24px;height:24px;border:3px solid #f0f0f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#ef44441a;color:#fca5a5;padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid rgba(239,68,68,.2);font-size:.875rem;line-height:1.5}.transcription-container{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:20px;margin-top:24px}.transcription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.transcription-header h2{font-size:1.125rem;color:#fff;margin:0;font-weight:600}.actions{display:flex;gap:8px;flex-shrink:0}.transcription-text{background:#0f1419;border:1px solid rgba(255,255,255,.06);padding:16px;border-radius:8px;min-height:100px;line-height:1.6;color:#e2e8f0;font-size:.9375rem;white-space:pre-wrap;word-wrap:break-word;font-family:system-ui,-apple-system,sans-serif}.transcription-text.meta-prompt{background:#3b82f60d;border:1px solid rgba(59,130,246,.2);color:#e2e8f0}.transcription-text.original-transcription{background:#ffffff05;border:1px solid rgba(255,255,255,.04);font-size:.875rem;color:#94a3b8}.meta-prompt-actions{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:12px}.research-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.research-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#10b981}.research-checkbox .checkbox-label{color:#94a3b8;font-size:.875rem;font-weight:400}.research-checkbox:hover .checkbox-label{color:#cbd5e1}.original-transcription-section{margin-top:20px}.placeholder{text-align:center;color:#64748b;padding:32px 16px;font-size:.9375rem;font-weight:400;line-height:1.5}@media(max-width:768px){.header-with-link{flex-direction:column;align-items:flex-start;gap:12px}.header-right{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px}h1{font-size:1.5rem}.subtitle{font-size:.875rem;margin:12px 0 20px}.record-control-container{margin:24px auto 32px}.transcription-header{flex-direction:column;align-items:flex-start;gap:12px}.actions{width:100%}.btn-secondary{flex:1;justify-content:center}}@media(max-width:480px){.card{padding:20px}h1{font-size:1.375rem}.header-right{grid-template-columns:repeat(2,1fr)}}.recording-indicator{display:flex;align-items:center;justify-content:center;gap:12px;margin:24px auto;padding:16px 32px;background:linear-gradient(135deg,#f44,#c00);border-radius:12px;box-shadow:0 4px 12px #ff44444d;max-width:300px}.recording-dot{width:16px;height:16px;background:#fff;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}.recording-text{color:#fff;font-weight:700;font-size:1rem;letter-spacing:2px}.recording-timer{color:#fff;font-weight:600;font-size:1.3rem;font-family:Courier New,monospace;min-width:60px}@media(min-width:769px){.app{padding:32px 24px}.card{padding:32px;max-width:720px}h1{font-size:2rem}.record-button{width:140px;height:140px}.mic-icon-large{font-size:3rem}.stop-icon,.spinner-icon{width:40px;height:40px}}@media(hover:none)and (pointer:coarse){.settings-link,.history-link,.admin-link,.logout-btn,.btn,.btn-secondary,.btn-meta-prompt{min-height:44px}}.history-page{width:100%;max-width:900px;margin:0 auto;padding:20px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;background:#1a1f2e;padding:24px;border-radius:16px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08);gap:16px}.header-content{flex:1;text-align:center}.history-header h1{font-size:2rem;color:#fff;margin:0}.header-actions{display:flex;gap:12px;align-items:center}.back-link{color:#3b82f6;text-decoration:none;font-weight:600;font-size:1.1rem;transition:color .2s}.back-link:hover{color:#60a5fa}.loading{text-align:center;padding:60px 20px;color:#94a3b8;font-size:1.2rem;background:#1a1f2e;border-radius:16px;border:1px solid rgba(255,255,255,.08)}.empty-state{text-align:center;padding:80px 20px;background:#1a1f2e;border-radius:16px;box-shadow:0 4px 24px #0006;border:1px solid rgba(255,255,255,.08)}.empty-state p{font-size:1.3rem;color:#64748b;margin-bottom:24px}.transcriptions-list{display:flex;flex-direction:column;gap:16px}.transcription-card{background:#1a1f2e;border-radius:12px;padding:24px;box-shadow:0 2px 12px #0000004d;border:1px solid rgba(255,255,255,.08);transition:transform .2s,box-shadow .2s}.transcription-card:hover{transform:translateY(-2px);box-shadow:0 4px 24px #00000080;border-color:#3b82f64d}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08)}.date{font-size:.95rem;color:#94a3b8;font-weight:600}.metadata{display:flex;gap:16px;align-items:center}.duration,.confidence{font-size:.9rem;color:#64748b;display:flex;align-items:center;gap:4px}.confidence:before{content:"✓";color:#10b981}.card-body{margin-bottom:16px}.card-body .text{font-size:1.05rem;line-height:1.6;color:#e2e8f0;margin:0;word-wrap:break-word}.card-body .meta-prompt-text{color:#93c5fd;border-left:2px solid rgba(59,130,246,.4);padding-left:12px;white-space:pre-wrap}.card-body .original-text{font-size:.9rem;color:#64748b;margin-top:12px;font-style:italic}.mode-badge{font-size:.75rem;font-weight:600;color:#93c5fd;background:#3b82f61f;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.03em}.card-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-small{padding:8px 16px;font-size:.9rem}@media(max-width:768px){.history-page{padding:10px}.history-header{flex-direction:column;gap:12px;padding:16px}.history-header h1{font-size:1.5rem}.header-actions{width:100%;justify-content:space-between}.header-actions .btn,.header-actions .back-link{font-size:.95rem}.transcription-card{padding:16px}.card-header{flex-direction:column;align-items:flex-start;gap:8px}.date{font-size:.9rem}.metadata{gap:12px}.duration,.confidence{font-size:.85rem}.card-body .text{font-size:1rem}.card-actions{flex-direction:column}.card-actions .btn-small{width:100%;justify-content:center}}@media(max-width:480px){.history-page{padding:5px}.history-header{padding:12px}.history-header h1{font-size:1.3rem}.header-actions .btn,.header-actions .back-link{font-size:.85rem;padding:6px 12px}.transcription-card{padding:12px}.card-body .text{font-size:.95rem}.empty-state{padding:60px 15px}.empty-state p{font-size:1.1rem}}*{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:#0f1419;min-height:100vh}#root{width:100%;min-height:100vh}
