:root{--primary-blue:#1e3a8a;--medium-blue:#3b82f6;--light-blue:#dbeafe;--white:#fff;--light-gray:#f3f4f6;--dark-gray:#6b7280;--success:#10b981;--error:#ef4444}body{background-color:#f3f4f6;background-color:var(--light-gray);color:#1e3a8a;color:var(--primary-blue);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 20px}button{font-family:inherit;transition:all .3s ease}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--light-gray)}::-webkit-scrollbar-thumb{background:#3b82f6;background:var(--medium-blue);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#1e3a8a;background:var(--primary-blue)}.audio-recorder{background:#fff;border:2px solid #dbeafe;border-radius:12px;box-shadow:0 2px 8px #2563eb14;padding:24px}.audio-recorder h3{align-items:center;color:#1e3a8a;display:flex;font-size:1.25rem;gap:8px;margin-bottom:20px}.playback-controls,.recording-controls{display:flex;flex-direction:column;gap:12px}.pause-btn,.play-btn,.reset-btn,.start-btn,.stop-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;min-height:44px;padding:12px 20px;transition:all .3s ease}.start-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #2563eb4d;color:#fff}.start-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.stop-btn{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #dc26264d;color:#fff;font-size:.95rem;padding:10px 16px}.stop-btn:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 6px 20px #dc262666;transform:translateY(-2px)}.play-btn{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 12px #16a34a4d;color:#fff}.play-btn:hover{background:linear-gradient(135deg,#15803d,#166534);box-shadow:0 6px 20px #16a34a66;transform:translateY(-2px)}.pause-btn{background:linear-gradient(135deg,#ea580c,#c2410c);box-shadow:0 4px 12px #ea580c4d;color:#fff}.pause-btn:hover{background:linear-gradient(135deg,#c2410c,#b45309);box-shadow:0 6px 20px #ea580c66;transform:translateY(-2px)}.reset-btn{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 4px 12px #6b72804d;color:#fff}.reset-btn:hover{background:linear-gradient(135deg,#4b5563,#374151);box-shadow:0 6px 20px #6b728066;transform:translateY(-2px)}.recording-indicator{align-items:center;background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #dc2626;border-radius:8px;display:flex;gap:16px;padding:16px}.pulse{animation:pulse 1.5s infinite;background-color:#dc2626;border-radius:50%;display:inline-block;height:12px;width:12px}.playback-info{background:linear-gradient(135deg,#dcfce7,#f0fdf4);border-left:4px solid #16a34a;border-radius:8px;padding:16px}.playback-info p{color:#15803d;font-size:.95rem;font-weight:500;margin:0}.button-group{display:flex;gap:12px}.button-group button{flex:1 1}@media (max-width:768px){.button-group{flex-direction:column}.pause-btn,.play-btn,.reset-btn,.start-btn,.stop-btn{font-size:.95rem;padding:10px 16px}}@media (max-width:480px){.audio-recorder{padding:16px}.audio-recorder h3{font-size:1.125rem}.playback-controls,.recording-controls{gap:10px}.pause-btn,.play-btn,.reset-btn,.start-btn,.stop-btn{font-size:.875rem;min-height:40px;padding:10px 12px}.recording-indicator{gap:12px;padding:12px}.playback-info{padding:12px}}.user-session{background:linear-gradient(135deg,#eff6ff,#dbeafe);min-height:100vh;padding:16px 16px 40px}.session-container{margin:0 auto;max-width:768px}.session-header{margin-bottom:32px;padding-top:24px;text-align:center}.session-header h1{color:#1e3a8a;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.session-header .subtitle{color:#2563eb;font-size:1.125rem;font-weight:500}.session-content{display:flex;flex-direction:column;gap:24px}@media (max-width:768px){.session-header h1{font-size:1.75rem}.subtitle{font-size:1rem}.session-content{gap:16px}}@media (max-width:480px){.session-header h1{font-size:1.5rem}.session-content{gap:12px}}.session-info{background:#fff;border:2px solid #dbeafe;border-radius:12px;box-shadow:0 2px 8px #2563eb14;padding:24px}.session-info h2{color:#1e3a8a;font-size:1.5rem;margin-bottom:8px}.session-date{color:#6b7280;font-size:.95rem;font-weight:500}.no-session{background:#fff;border:2px solid #dbeafe;border-radius:12px;padding:48px 24px;text-align:center}.no-session h1{color:#1e3a8a;margin-bottom:16px}.no-session p{color:#6b7280;font-size:1.125rem}.reference-audio{background:#fff;border-left:4px solid #2563eb;border-radius:12px;box-shadow:0 2px 8px #2563eb14;padding:24px}.reference-audio h3{align-items:center;color:#1e3a8a;display:flex;font-size:1.25rem;gap:8px;margin-bottom:16px}.reference-audio audio{background:#f3f4f6;border-radius:8px;height:40px;margin:16px 0;padding:8px;width:100%}.audio-note{color:#6b7280;font-size:.875rem;font-style:italic;margin-top:12px}.script-section{background:#fff;border:2px solid #dbeafe;border-radius:12px;box-shadow:0 2px 8px #2563eb14;padding:24px}.script-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.script-section h3{align-items:center;color:#1e3a8a;display:flex;flex-grow:1;font-size:1.25rem;gap:8px;margin:0}.font-size-controls{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;gap:10px;padding:8px 12px}.font-btn,.font-size-controls{align-items:center;display:flex}.font-btn{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.25rem;font-weight:700;height:36px;justify-content:center;min-width:36px;padding:6px 12px;transition:all .2s ease}.font-btn:hover{background:#1d4ed8;box-shadow:0 2px 6px #2563eb4d;transform:scale(1.05)}.font-btn:active{transform:scale(.98)}.font-minus{background:#ef4444}.font-minus:hover{background:#dc2626}.font-plus{background:#16a34a}.font-plus:hover{background:#15803d}.font-size-display{font-size:.9rem;font-weight:600;min-width:50px;text-align:center}.script-text{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid #e5e7eb;border-radius:8px;color:#111827;font-size:1.125rem;line-height:1.8;min-height:120px;padding:20px;text-align:justify}.recorded-message,.script-text{align-items:center;display:flex;justify-content:center}.recorded-message{background:#dcfce7;border:2px solid #16a34a;border-radius:8px;color:#15803d;font-size:1rem;font-weight:500;gap:8px;padding:16px 20px;text-align:center}.feedback-options{background:#fff;border:2px solid #dbeafe;border-radius:12px;box-shadow:0 2px 8px #2563eb14;padding:24px}.consent-checkbox,.feedback-toggle{align-items:center;color:#111827;cursor:pointer;display:flex;font-size:.95rem;gap:12px;transition:color .2s ease;-webkit-user-select:none;user-select:none}.consent-checkbox:hover,.feedback-toggle:hover{color:#2563eb}.consent-checkbox input,.feedback-toggle input{accent-color:#16a34a;appearance:none;background-color:#fff;border:2px solid #16a34a;border-radius:4px;cursor:pointer;flex-shrink:0;height:20px;position:relative;width:20px}.consent-checkbox input:checked,.feedback-toggle input:checked{background-color:#16a34a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:100% 100%}.consent-checkbox input:focus,.feedback-toggle input:focus{outline:2px solid #16a34a;outline-offset:2px}.consent-section{animation:slideIn .3s ease;background:#f9fafb;border-left:4px solid #ea580c;border-radius:8px;margin-top:16px;padding:16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message{border:2px solid #dc2626}.error-message,.success-message{align-items:center;display:flex;gap:8px;padding:16px 20px}.success-message{background:#dcfce7;border:2px solid #16a34a;border-radius:8px;color:#15803d;font-weight:500}.submit-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:8px;box-shadow:0 4px 12px #2563eb4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;margin-top:16px;padding:14px 28px;text-transform:uppercase;transition:all .3s ease;width:100%}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.feedback-section{background:#fff;border:2px solid #16a34a;border-radius:12px;box-shadow:0 4px 16px #16a34a1f;padding:28px}.feedback-section h3{align-items:center;color:#15803d;display:flex;font-size:1.5rem;gap:8px;margin-bottom:24px}.feedback-section h4{color:#1e3a8a;font-size:1.125rem;margin-bottom:12px;margin-top:24px}.scores{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:24px}.score-item{background:linear-gradient(135deg,#dcfce7,#f0fdf4);border:2px solid #16a34a;border-radius:12px;padding:16px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.score-item:hover{box-shadow:0 6px 16px #16a34a26;transform:translateY(-4px)}.score-label{color:#15803d;font-size:.75rem;font-weight:600;margin-bottom:8px}.score-value{color:#15803d;font-family:Courier New,monospace}.comments{background:#f9fafb;border-radius:8px;margin-top:16px;padding:16px}.comment{border-left:3px solid #2563eb;color:#374151;font-size:.95rem;line-height:1.6;margin:12px 0;padding:8px 8px 8px 12px}.comment:first-child{margin-top:0}.transcription-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #2563eb;border-radius:8px;margin-top:16px;padding:16px}.transcription-section h4{align-items:center;color:#1e3a8a;display:flex;font-size:1rem;gap:6px;margin:0 0 12px}.transcription-text{background:#fff;border-left:3px solid #2563eb;border-radius:6px;color:#111827;font-size:1rem;font-style:italic;line-height:1.6;margin:0;padding:12px}.new-session-btn{background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:8px;box-shadow:0 4px 12px #16a34a4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;margin-top:24px;padding:14px 28px;text-transform:uppercase;transition:all .3s ease;width:100%}.new-session-btn:hover{background:linear-gradient(135deg,#15803d,#166534);box-shadow:0 6px 20px #16a34a66;transform:translateY(-2px)}.session-footer{border-top:1px solid #e5e7eb;margin-top:32px;padding:24px 0;text-align:center}.session-footer p{color:#6b7280;font-size:.875rem}.session-footer a{color:#2563eb;font-weight:500;text-decoration:none;transition:color .2s ease}.session-footer a:hover{color:#1d4ed8;text-decoration:underline}@media (max-width:640px){.user-session{padding:12px}.session-header h1{font-size:1.75rem}.subtitle{font-size:1rem}.feedback-options,.feedback-section,.reference-audio,.script-section,.session-info{padding:20px}.script-header{align-items:flex-start;flex-direction:column;gap:12px}.font-size-controls{justify-content:center;width:100%}.scores{gap:12px;grid-template-columns:repeat(2,1fr)}.score-value{font-size:1.75rem}.new-session-btn,.submit-btn{font-size:.95rem;padding:12px 20px}}@media (max-width:480px){.session-header h1{font-size:1.5rem}.feedback-options,.feedback-section,.reference-audio,.script-section,.session-info{border-radius:8px;padding:16px}.session-content{gap:12px}.scores{grid-template-columns:1fr}.score-item{padding:12px}.score-value{font-size:1.5rem}.script-text{font-size:1rem;line-height:1.6;min-height:100px;padding:16px}.feedback-section h3{font-size:1.25rem}.comments{padding:12px}.comment{font-size:.875rem;margin:8px 0;padding:6px 6px 6px 10px}.transcription-section{margin-top:12px;padding:12px}.transcription-section h4{font-size:.95rem}.transcription-text{font-size:.875rem;padding:10px}.font-size-controls{gap:8px;padding:8px}.font-btn{font-size:1.1rem;height:32px;min-width:32px;padding:4px 8px}.font-size-display{font-size:.85rem;min-width:45px}}.admin-login{align-items:center;background:linear-gradient(135deg,#1e3a8a,#2563eb);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{max-width:400px;width:100%}.login-box{background-color:#fff;border-radius:12px;box-shadow:0 12px 32px #1e3a8a40;padding:40px}.login-box h1{color:#1e3a8a;font-size:1.75rem;font-weight:700;margin-bottom:8px;text-align:center}.login-box .subtitle{color:#6b7280;font-size:.875rem;margin-bottom:32px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#1e3a8a;font-size:.875rem;margin-bottom:8px}.form-group input{border:2px solid #dbeafe;border-radius:8px;color:#111827;font-family:inherit;font-size:1rem;padding:12px;transition:all .3s ease;width:100%}.form-group input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group input::placeholder{color:#9ca3af}.login-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:8px;box-shadow:0 4px 12px #2563eb4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:16px;padding:12px;transition:all .3s ease;width:100%}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fee2e2;border-left:4px solid #dc2626;border-radius:8px;font-size:.95rem;font-weight:500}.back-link{margin-top:24px;text-align:center}.back-link a{color:#2563eb;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .3s ease}.back-link a:hover{color:#1d4ed8;text-decoration:underline}@media (max-width:768px){.login-box{padding:30px 20px}.login-box h1{font-size:1.5rem}}@media (max-width:480px){.admin-login{padding:16px}.login-box{padding:24px 16px}.login-box h1{font-size:1.25rem}.form-group input{font-size:16px!important}.login-btn{font-size:.95rem;padding:10px}}.sessions-container{background-color:var(--white);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:32px}.sessions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.sessions-header h2{color:var(--primary-blue);font-size:24px}.add-session-btn{background-color:var(--medium-blue);border:none;border-radius:6px;color:var(--white);cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background-color .3s ease}.add-session-btn:hover{background-color:var(--primary-blue)}.session-form{background-color:var(--light-gray);border:2px solid var(--light-blue);border-radius:8px;margin-bottom:32px;padding:24px}.session-form h3{color:var(--primary-blue);font-size:18px;margin-bottom:20px}.form-group{margin-bottom:16px}.form-group label{color:var(--primary-blue);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input,.form-group textarea{border:1px solid var(--light-blue);border-radius:6px;color:var(--primary-blue);font-family:inherit;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group textarea:focus{background-color:var(--white);border-color:var(--medium-blue);outline:none}.form-group.checkbox,.form-group.checkbox label{align-items:center;display:flex}.form-group.checkbox label{gap:8px;margin:0}.form-group.checkbox input{cursor:pointer;width:auto}.form-buttons{display:flex;gap:12px;margin-top:24px}.cancel-btn,.edit-btn,.save-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s ease}.save-btn{background-color:var(--medium-blue);color:var(--white);flex:1 1}.save-btn:hover{background-color:var(--primary-blue)}.cancel-btn{background-color:var(--dark-gray);color:var(--white);flex:1 1}.cancel-btn:hover{background-color:#4b5563}.edit-btn{background-color:var(--medium-blue);color:var(--white);font-size:12px;padding:8px 12px}.edit-btn:hover{background-color:var(--primary-blue)}.sessions-table{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}table thead{background-color:var(--light-blue);border-bottom:2px solid var(--medium-blue)}table th{color:var(--primary-blue);font-weight:600;padding:12px;text-align:left}table td{border-bottom:1px solid #e5e7eb;color:var(--dark-gray);padding:12px}table tbody tr:hover{background-color:var(--light-gray)}.script-preview{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audio-status{font-weight:600;text-align:center}.status{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.status.active{background-color:#d1fae5;color:#065f46}.status.inactive{background-color:#fee2e2;color:#991b1b}.actions{display:flex;gap:8px}.upload-btn{background-color:var(--success);border:none;border-radius:6px;color:var(--white);cursor:pointer;font-size:12px;font-weight:600;padding:8px 12px;transition:background-color .3s ease}.upload-btn:hover{background-color:#059669}.no-sessions{color:var(--dark-gray);padding:40px;text-align:center}@media (max-width:768px){.sessions-container{padding:16px}.sessions-header{flex-direction:column;gap:12px}.sessions-header h2{font-size:20px}.add-session-btn{width:100%}table{font-size:12px}table td,table th{padding:8px}.script-preview{max-width:80px}.actions{flex-direction:column}.edit-btn,.upload-btn{width:100%}}.analytics-container{background-color:var(--white);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:32px}.analytics-container>h2{color:var(--primary-blue);font-size:24px;margin-bottom:32px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.stat-card{align-items:center;background:linear-gradient(135deg,var(--light-blue) 0,var(--white) 100%);border:2px solid var(--light-blue);border-radius:8px;display:flex;gap:16px;padding:24px;transition:all .3s ease}.stat-card:hover{border-color:var(--medium-blue);box-shadow:0 4px 12px #3b82f626}.stat-icon{font-size:32px}.stat-content{flex:1 1}.stat-label{color:var(--dark-gray);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.stat-value{color:var(--medium-blue);display:block;font-size:28px;font-weight:700}.current-week{background-color:var(--light-gray);border-radius:8px;margin-bottom:40px;padding:24px}.current-week h3{color:var(--primary-blue);font-size:18px;margin-bottom:16px}.week-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.week-stat{background-color:var(--white);border-left:4px solid var(--medium-blue);border-radius:6px;padding:16px;text-align:center}.week-label{color:var(--dark-gray);display:block;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.week-value{color:var(--medium-blue);display:block;font-size:24px;font-weight:700}.daily-participation{background-color:var(--white);border-radius:8px;margin-bottom:24px;padding:24px}.daily-participation h3{color:var(--primary-blue);font-size:18px;margin-bottom:16px}.daily-participation table{border-collapse:collapse;font-size:14px;width:100%}.daily-participation thead{background-color:var(--light-blue);border-bottom:2px solid var(--medium-blue)}.daily-participation th{color:var(--primary-blue);font-weight:600;padding:12px;text-align:left}.daily-participation td{border-bottom:1px solid #e5e7eb;color:var(--dark-gray);padding:12px}.daily-participation tbody tr:hover{background-color:var(--light-gray)}.refresh-btn{background-color:var(--medium-blue);border:none;border-radius:6px;color:var(--white);cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background-color .3s ease}.refresh-btn:hover{background-color:var(--primary-blue)}@media (max-width:768px){.analytics-container{padding:16px}.stats-grid{gap:12px;grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center}.week-stats{grid-template-columns:1fr 1fr}.current-week{margin-bottom:24px}.daily-participation table{font-size:12px}.daily-participation td,.daily-participation th{padding:8px}.daily-participation h3{font-size:16px}.refresh-btn{width:100%}}.admin-dashboard{background:linear-gradient(135deg,#f9fafb,#f3f4f6);min-height:100vh}.dashboard-header{align-items:center;background:linear-gradient(135deg,#1e3a8a,#2563eb);box-shadow:0 4px 16px #1e3a8a33;color:#fff;display:flex;justify-content:space-between;padding:32px 40px}.header-content h1{font-size:2rem;font-weight:700;margin-bottom:4px}.header-content p{font-size:.95rem;font-weight:500;opacity:.95}.logout-btn{background-color:#ffffff26;border:2px solid #ffffff80;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 24px;transition:all .3s ease}.logout-btn:hover{background-color:#ffffff40;border-color:#fff;transform:translateY(-2px)}.dashboard-nav{background-color:#fff;border-bottom:2px solid #dbeafe;box-shadow:0 2px 8px #0000000d;display:flex;gap:0;padding:0 40px}.nav-btn{background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:1rem;font-weight:600;padding:16px 24px;position:relative;transition:all .3s ease}.nav-btn:hover{color:#2563eb}.nav-btn.active{border-bottom-color:#2563eb;color:#2563eb}.dashboard-content{margin:0 auto;max-width:1400px;padding:40px}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:16px;padding:24px 20px}.header-content h1{font-size:1.5rem}.dashboard-nav{-webkit-overflow-scrolling:touch;overflow-x:auto;padding:0 20px}.nav-btn{font-size:.9rem;padding:12px 16px;white-space:nowrap}.dashboard-content{padding:20px}}@media (max-width:480px){.dashboard-header{padding:16px}.header-content h1{font-size:1.25rem}.header-content{width:100%}.logout-btn{text-align:center;width:100%}.dashboard-nav{padding:0}.nav-btn{font-size:.85rem}.dashboard-content,.nav-btn{padding:12px}}:root{--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-50:#eff6ff;--success-600:#16a34a;--success-700:#15803d;--error-600:#dc2626;--error-700:#b91c1c;--warning-600:#ea580c;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-600:#4b5563;--gray-900:#111827}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-family:Inter,system-ui,-apple-system,sans-serif;overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9fafb;background:var(--gray-50);color:#111827;color:var(--gray-900);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}h1{font-size:2rem}h1,h2{color:#111827;color:var(--gray-900)}h2{font-size:1.5rem}h3{color:#111827;color:var(--gray-900);font-size:1.25rem}p{color:#4b5563;color:var(--gray-600);margin-bottom:.5rem}button{-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;cursor:pointer;font-size:16px!important;font-weight:500;min-height:48px;min-width:48px;overflow:hidden;position:relative;transition:all .2s ease}button:active{transform:scale(.98)}button:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#2563eb;background:var(--primary-600);border-radius:8px;color:#fff;padding:12px 24px}.btn-primary:hover{background:#1d4ed8;background:var(--primary-700);box-shadow:0 4px 12px #2563eb33}.btn-secondary{background:#e5e7eb;background:var(--gray-200);border-radius:8px;color:#111827;color:var(--gray-900);padding:10px 20px}.btn-secondary:hover{background:#d1d5db;background:var(--gray-300)}.btn-success{background:#16a34a;background:var(--success-600);border-radius:8px;color:#fff;padding:12px 24px}.btn-success:hover{background:#15803d;background:var(--success-700);box-shadow:0 4px 12px #16a34a33}.btn-error{background:#dc2626;background:var(--error-600);border-radius:8px;color:#fff;padding:12px 24px}.btn-error:hover{background:#b91c1c;background:var(--error-700);box-shadow:0 4px 12px #dc262633}input,select,textarea{appearance:none;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:8px;font-family:inherit;font-size:16px!important;padding:12px;transition:all .2s ease;width:100%}input:focus,select:focus,textarea:focus{border-color:#2563eb;border-color:var(--primary-600);box-shadow:0 0 0 3px #2563eb1a;outline:none}textarea{min-height:100px;resize:vertical}.card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:all .2s ease}.card:hover{border-color:#2563eb;border-color:var(--primary-600);box-shadow:0 4px 12px #00000014}.score-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:20px 0}.score-box{background:linear-gradient(135deg,#eff6ff,#fff);background:linear-gradient(135deg,var(--primary-50) 0,#fff 100%);border:2px solid #2563eb;border:2px solid var(--primary-600);border-radius:12px;padding:16px;text-align:center}.score-box.excellent{background:linear-gradient(135deg,#dcfce7,#fff);border-color:#16a34a;border-color:var(--success-600)}.score-box.good{background:linear-gradient(135deg,#eff6ff,#fff);background:linear-gradient(135deg,var(--primary-50) 0,#fff 100%);border-color:#2563eb;border-color:var(--primary-600)}.score-box.needs-work{background:linear-gradient(135deg,#fed7aa,#fff);border-color:#ea580c;border-color:var(--warning-600)}.score-value{font-size:2rem;font-weight:700;margin:8px 0}.score-label{color:#4b5563;color:var(--gray-600);font-size:.875rem;letter-spacing:.5px;text-transform:uppercase}.feedback-section{background:#f9fafb;background:var(--gray-50);border-left:4px solid #2563eb;border-left:4px solid var(--primary-600);border-radius:8px;margin:16px 0;padding:16px}.feedback-item{align-items:flex-start;display:flex;margin:8px 0}.feedback-icon{flex-shrink:0;height:20px;margin-right:12px;margin-top:2px;width:20px}.feedback-text{color:var(--gray-700);font-size:.95rem;line-height:1.5}.recording-timer{align-items:center;background:#eff6ff;background:var(--primary-50);border:2px solid #2563eb;border:2px solid var(--primary-600);border-radius:8px;display:flex;gap:12px;justify-content:center;margin:16px 0;padding:16px}.timer-value{color:#2563eb;color:var(--primary-600);font-family:Courier New,monospace;font-size:2rem;font-weight:700}.recording-pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}audio{margin:12px 0;outline:none;width:100%}audio::-webkit-media-controls-panel{background-color:#eff6ff;background-color:var(--primary-50)}audio::-webkit-media-controls-current-time-display{color:#2563eb;color:var(--primary-600)}.script-display{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;color:#111827;color:var(--gray-900);line-height:1.8;max-height:400px;overflow-y:auto;padding:20px}.script-display::-webkit-scrollbar{width:6px}.script-display::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100);border-radius:10px}.script-display::-webkit-scrollbar-thumb{background:#2563eb;background:var(--primary-600);border-radius:10px}.script-display::-webkit-scrollbar-thumb:hover{background:#1d4ed8;background:var(--primary-700)}.controls{display:flex;flex-wrap:wrap;gap:12px;margin:16px 0}.control-button{align-items:center;display:inline-flex;font-size:.95rem;gap:8px;padding:10px 16px}.control-button svg{height:18px;width:18px}.font-size-control{align-items:center;display:flex;gap:12px;margin:12px 0}.font-size-btn{align-items:center;display:flex;font-size:.875rem;gap:4px;padding:8px 12px}.font-size-display{color:#4b5563;color:var(--gray-600);font-size:.875rem;min-width:100px}@media (max-width:768px){h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}.card{padding:16px}.score-container{grid-template-columns:1fr}.controls{gap:8px}.control-button{font-size:.875rem;padding:8px 12px}button{min-height:44px;min-width:44px}input,select,textarea{font-size:16px!important;padding:10px}.script-display{max-height:300px;padding:16px}}@media (max-width:480px){.card{border-radius:8px;padding:12px}h1{font-size:1.25rem}.score-value,.timer-value{font-size:1.5rem}.controls{flex-direction:column}.control-button{justify-content:center;width:100%}.recording-timer{gap:8px;padding:12px}}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-top-color:#2563eb;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-600);display:inline-block;height:24px;width:24px}@keyframes spin{to{transform:rotate(1turn)}}.message{border-left:4px solid;border-radius:8px;margin:12px 0;padding:12px 16px}.message.success{background:#dcfce7;border-left-color:#16a34a;border-left-color:var(--success-600);color:#15803d;color:var(--success-700)}.message.error{background:#fee2e2;border-left-color:#dc2626;border-left-color:var(--error-600);color:#b91c1c;color:var(--error-700)}.message.info{background:#eff6ff;background:var(--primary-50);border-left-color:#2563eb;border-left-color:var(--primary-600);color:#1d4ed8;color:var(--primary-700)}:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-600);outline-offset:2px}button:focus-visible{outline-offset:0}.text-center{text-align:center}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.p-4{padding:1rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.hidden{display:none!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center,.loading-spinner{justify-content:center}.loading-spinner{align-items:center;color:var(--primary-blue);display:flex;font-size:18px;height:100vh}.error-message{background-color:#fee2e2;border-left:4px solid var(--error);color:#991b1b}.error-message,.success-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:12px 16px}.success-message{background-color:#d1fae5;border-left:4px solid var(--success);color:#065f46}
/*# sourceMappingURL=main.ba3447d1.css.map*/