.roleplay-container{background-color:#f8fafc;color:var(--text);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column}.roleplay-steps{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:3rem;background:transparent;padding:0;box-shadow:none}.roleplay-step{font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;border-radius:9999px;transition:all .3s ease;color:var(--text-secondary);background-color:#fff;box-shadow:0 2px 4px #0000000d;border:1px solid transparent}.roleplay-step.active{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.roleplay-main{flex-grow:1;padding:0 1rem 3rem}.roleplay-content{max-width:1200px;margin:0 auto}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) forwards}.setup-container{max-width:1000px;margin:0 auto;background-color:#fff;border:1px solid rgba(226,232,240,.8);border-radius:1.5rem;padding:3rem;box-shadow:0 20px 40px -10px #0000000d}.setup-header-content{text-align:center;margin-bottom:3rem}.setup-heading{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.75rem;letter-spacing:-.02em}.setup-description{color:var(--text-secondary);font-size:1.1rem;max-width:600px;margin:0 auto;line-height:1.6}.setup-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:3rem}@media(min-width:768px){.setup-grid{grid-template-columns:1fr 1fr}}.setup-section{display:flex;flex-direction:column;gap:1.5rem}.setup-section.full-width{grid-column:1 / -1}.section-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.section-label:after{content:"";flex:1;height:1px;background-color:#f1f5f9}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-label{font-size:.9rem;font-weight:600;color:#334155}.form-input,.form-select{width:100%;background-color:#f8fafc;border:1px solid #e2e8f0;color:#1e293b;padding:.875rem 1rem;border-radius:.75rem;font-size:1rem;transition:all .2s ease}.form-input:hover,.form-select:hover{border-color:#cbd5e1}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 4px #6366f11a}.voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.voice-card{border:1px solid #e2e8f0;border-radius:1rem;padding:1.25rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:1rem;background-color:#fff;position:relative;overflow:hidden}.voice-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 10px 20px -5px #0000000d}.voice-card.selected{border-color:var(--primary);background-color:#eef2ff;box-shadow:0 4px 6px -1px #6366f11a}.voice-icon{font-size:1.75rem;background-color:#f1f5f9;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.voice-card.selected .voice-icon{background-color:#fff}.voice-info{flex:1;display:flex;flex-direction:column}.voice-name{font-weight:700;font-size:.95rem;color:#1e293b}.voice-desc{font-size:.8rem;color:#64748b}.radio-circle{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #cbd5e1;position:relative;transition:all .2s}.voice-card.selected .radio-circle{border-color:var(--primary);background-color:var(--primary)}.radio-circle.active:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:.5rem;height:.5rem;background-color:#fff;border-radius:50%}.btn-start{width:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;font-weight:700;padding:1.25rem;border-radius:1rem;border:none;cursor:pointer;transition:all .3s ease;font-size:1.125rem;box-shadow:0 4px 6px -1px #4f46e54d;margin-top:2rem;letter-spacing:.02em}.btn-start:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #4f46e566;filter:brightness(1.1)}.session-layout{display:flex;flex-direction:column;gap:2rem;min-height:650px}@media(min-width:1024px){.session-layout{flex-direction:row}}.visualizer-container{flex:1;background:linear-gradient(to bottom,#1e293b,#0f172a);border-radius:1.5rem;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;box-shadow:0 25px 50px -12px #00000040;color:#fff;border:1px solid rgba(255,255,255,.05)}.avatar-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24rem;height:24rem;background-color:#6366f133;border-radius:50%;filter:blur(100px);transition:all .3s ease-out}.avatar-glow.speaking{transform:translate(-50%,-50%) scale(1.3);opacity:1;background-color:#6366f166}.avatar-circle{width:9rem;height:9rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;font-weight:800;color:#fff;z-index:10;box-shadow:0 20px 25px -5px #0003;transition:all .3s;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:4px solid rgba(255,255,255,.1)}.status-badge{padding:.5rem 1.25rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:.75rem;margin-top:2rem;background-color:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 6px -1px #0000001a}.status-badge.speaking{color:#a5b4fc;border-color:#6366f14d}.status-badge.listening{color:#94a3b8}.audio-bars{height:4rem;display:flex;align-items:center;justify-content:center;gap:.375rem;margin-top:3rem}.audio-bar{width:.5rem;background-color:#fff3;border-radius:9999px;transition:height .05s ease}.btn-end-call{position:absolute;bottom:2.5rem;background-color:#ef4444e6;color:#fff;padding:.875rem 2.5rem;border-radius:9999px;font-weight:600;border:none;cursor:pointer;box-shadow:0 10px 15px -3px #ef44444d;transition:all .2s;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-end-call:hover{background-color:#ef4444;transform:scale(1.05)}.transcript-container{width:100%;background-color:#fff;border:1px solid var(--border);border-radius:1.5rem;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg);height:650px}@media(min-width:1024px){.transcript-container{width:28rem}}.transcript-header{padding:1.5rem;border-bottom:1px solid var(--border);background-color:#fff;display:flex;align-items:center;justify-content:space-between}.transcript-title{font-size:.9rem;font-weight:800;color:#1e293b;text-transform:uppercase;letter-spacing:.05em}.transcript-body{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;background-color:#f8fafc}.message{display:flex;flex-direction:column;max-width:85%}.message.user{align-self:flex-end;align-items:flex-end}.message.model{align-self:flex-start;align-items:flex-start}.message-label{font-size:.7rem;font-weight:600;color:#64748b;margin-bottom:.375rem;padding:0 .25rem}.message-bubble{padding:1rem 1.25rem;border-radius:1.25rem;font-size:.95rem;line-height:1.6;box-shadow:0 2px 4px #0000000d}.message.user .message-bubble{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-bottom-right-radius:.25rem}.message.model .message-bubble{background-color:#fff;color:#1e293b;border:1px solid #e2e8f0;border-bottom-left-radius:.25rem}.feedback-container{max-width:64rem;margin:0 auto;padding-bottom:4rem}.score-card{background:#fff;padding:3rem;border-radius:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:3rem;margin-bottom:3rem}@media(min-width:768px){.score-card{flex-direction:row}}.score-circle{position:relative;width:10rem;height:10rem;display:flex;align-items:center;justify-content:center}.score-value{font-size:3.5rem;font-weight:800;color:var(--primary);letter-spacing:-.02em}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:3rem}@media(min-width:768px){.metrics-grid{grid-template-columns:repeat(4,1fr)}}.metric-card{background-color:#fff;padding:1.5rem;border-radius:1rem;border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.metric-label{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.metric-value{font-size:1.75rem;font-weight:800;color:#1e293b}.metric-bar-bg{width:100%;height:.5rem;background-color:#f1f5f9;border-radius:9999px;margin-top:1rem;overflow:hidden}.metric-bar-fill{height:100%;background-color:var(--primary);border-radius:9999px}.analysis-grid{display:grid;gap:2rem}@media(min-width:768px){.analysis-grid{grid-template-columns:repeat(2,1fr)}}.analysis-card{background-color:#fff;padding:2rem;border-radius:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow)}.analysis-title{font-size:1.25rem;font-weight:800;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.analysis-title.strengths{color:var(--success)}.analysis-title.weaknesses{color:var(--warning)}.analysis-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.analysis-item{display:flex;gap:1rem;color:#334155;line-height:1.6}.btn-reset{background-color:var(--primary);color:#fff;padding:1rem 3rem;border-radius:9999px;font-weight:700;border:none;cursor:pointer}.btn-reset:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 20px 25px -5px #6366f166}.scenario-list-container{max-width:1200px;margin:0 auto}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem}.card{background:#fff;border-radius:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.card-header{padding:1.5rem 1.5rem 1rem}.scenario-card .badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef9c3;color:#854d0e}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}th{text-align:left;padding:1rem 1.5rem;font-size:.85rem;font-weight:700;text-transform:uppercase;color:#64748b;border-bottom:1px solid #e2e8f0;background-color:#f8fafc}td{padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;color:#334155}tr:last-child td{border-bottom:none}tr:hover td{background-color:#f8fafc}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.5rem;font-weight:600;transition:all .2s;cursor:pointer;border:1px solid transparent}.btn-outline{background-color:#fff;border-color:#e2e8f0;color:#64748b}.btn-outline:hover{border-color:#cbd5e1;background-color:#f8fafc;color:#334155}.btn-danger{background-color:#fee2e2;color:#991b1b}.btn-danger:hover{background-color:#fecaca}.loading{display:flex;justify-content:center;align-items:center;min-height:300px}.spinner{width:3rem;height:3rem;border:4px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.roleplay-start-screen{display:flex;align-items:center;justify-content:center;min-height:500px;padding:2rem}.start-screen-content{text-align:center;max-width:600px;width:100%}.scenario-preview{background:#fff;border-radius:1.5rem;padding:2.5rem;box-shadow:0 20px 40px -10px #0000001a;border:1px solid var(--border);margin-bottom:2rem}.persona-avatar{width:5rem;height:5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;margin:0 auto 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.persona-avatar.large{width:6rem;height:6rem;font-size:2.5rem}.persona-avatar.small{width:3rem;height:3rem;font-size:1.25rem;margin:0}.persona-avatar.female{background:linear-gradient(135deg,#ec4899,#f472b6)}.scenario-preview h2{font-size:1.75rem;font-weight:800;color:#1e293b;margin-bottom:.5rem}.scenario-desc{color:#64748b;margin-bottom:1.5rem;line-height:1.6}.persona-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;text-align:left;margin-bottom:1.5rem}.persona-info-item{background:#f8fafc;padding:.75rem 1rem;border-radius:.75rem;border:1px solid #e2e8f0}.persona-info-item .label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;color:#94a3b8;margin-bottom:.25rem}.persona-info-item .value{font-weight:600;color:#334155;font-size:.9rem}.training-goals-preview{text-align:left;background:#eef2ff;padding:1rem;border-radius:.75rem;border:1px solid #c7d2fe}.training-goals-preview h4{font-size:.9rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.training-goals-preview p{font-size:.85rem;color:#4338ca;margin:0;white-space:pre-line}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:.75rem;margin-bottom:1rem}.btn-start-session{width:100%;padding:1.25rem 2rem;font-size:1.125rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--primary),#7c3aed);border:none;border-radius:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #6366f166}.btn-start-session:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #6366f180}.btn-start-session:disabled{opacity:.7;cursor:wait}.start-hint{color:#94a3b8;font-size:.85rem;margin-top:1rem}.roleplay-session-active{display:flex;flex-direction:column;height:700px;background:#fff;border-radius:1.5rem;overflow:hidden;box-shadow:0 20px 40px -10px #0000001a;border:1px solid var(--border)}.session-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid var(--border)}.session-info{display:flex;align-items:center;gap:1rem}.session-info h3{font-size:1rem;font-weight:700;color:#1e293b;margin:0}.scenario-badge{font-size:.75rem;color:#64748b}.btn-end-session{padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;color:#fff;background:#ef4444;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.btn-end-session:hover{background:#dc2626}.session-main{display:flex;flex:1;min-height:0}.audio-visualizer-panel{flex:0 0 40%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(to bottom,#1e293b,#0f172a);color:#fff}.visualizer-circle{width:8rem;height:8rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#6366f133;transition:all .3s ease;margin-bottom:1.5rem}.visualizer-circle.speaking{background:#6366f166;box-shadow:0 0 60px #6366f180;transform:scale(1.1)}.visualizer-circle.listening{background:#34d3994d;box-shadow:0 0 40px #34d39966}.visualizer-inner{font-size:2.5rem}.status-text{font-size:.9rem;color:#94a3b8;margin-bottom:1.5rem}.audio-level-bar{width:80%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.audio-level-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .1s ease}.transcript-panel{flex:1;display:flex;flex-direction:column;border-left:1px solid var(--border)}.transcript-panel .transcript-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:#fff}.transcript-panel .transcript-header h4{margin:0;font-size:.9rem;font-weight:700;color:#1e293b}.message-count{font-size:.75rem;color:#94a3b8;background:#f1f5f9;padding:.25rem .75rem;border-radius:9999px}.transcript-messages{flex:1;overflow-y:auto;padding:1rem;background:#f8fafc;display:flex;flex-direction:column;gap:.75rem}.empty-transcript{text-align:center;color:#94a3b8;font-style:italic;padding:3rem 1rem}.transcript-message{max-width:85%}.transcript-message.user{align-self:flex-end}.transcript-message.model{align-self:flex-start}.transcript-message .message-role{font-size:.7rem;font-weight:600;color:#64748b;margin-bottom:.25rem;padding:0 .5rem}.transcript-message .message-text{padding:.75rem 1rem;border-radius:1rem;font-size:.9rem;line-height:1.5}.transcript-message.user .message-text{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;border-bottom-right-radius:.25rem}.transcript-message.model .message-text{background:#fff;color:#1e293b;border:1px solid #e2e8f0;border-bottom-left-radius:.25rem}.session-error{background:#fee2e2;color:#991b1b;padding:.75rem 1rem;text-align:center;font-size:.875rem}@media(max-width:768px){.session-main{flex-direction:column}.audio-visualizer-panel{flex:0 0 auto;padding:1.5rem}.transcript-panel{border-left:none;border-top:1px solid var(--border)}.persona-info-grid{grid-template-columns:1fr}}.scenario-list-page{max-width:1200px;margin:0 auto;padding:0}.scenario-list-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:#64748b}.scenario-list-header{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-radius:1.5rem;margin-bottom:2rem;color:#fff}.header-icon{font-size:3rem;margin-bottom:1rem}.scenario-list-header h1{font-size:2.25rem;font-weight:800;margin-bottom:.5rem;letter-spacing:-.02em}.scenario-list-header p{font-size:1.1rem;opacity:.9}.stats-summary{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;border:1px solid var(--border)}.stat-item{text-align:center;padding:0 2rem}.stat-item:not(:last-child){border-right:1px solid var(--border)}.stat-value{display:block;font-size:2rem;font-weight:800;color:var(--primary)}.stat-label{font-size:.8rem;font-weight:600;text-transform:uppercase;color:#64748b;letter-spacing:.05em}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:1.5rem;border:1px solid var(--border)}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.empty-state p{color:#64748b}.scenario-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.scenario-card-new{background:#fff;border-radius:1.25rem;padding:1.5rem;border:1px solid var(--border);box-shadow:0 4px 6px -1px #0000000d;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden}.scenario-card-new:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),#8b5cf6);opacity:0;transition:opacity .3s}.scenario-card-new:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a;border-color:var(--primary)}.scenario-card-new:hover:before{opacity:1}.card-top{display:flex;justify-content:space-between;align-items:center}.difficulty-badge{padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700}.score-badge{background:#fef3c7;color:#92400e;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700}.scenario-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.scenario-description{font-size:.9rem;color:#64748b;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.persona-preview{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8fafc;border-radius:.75rem}.mini-avatar{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.mini-avatar.female{background:linear-gradient(135deg,#ec4899,#f472b6)}.persona-details{display:flex;flex-direction:column}.persona-name{font-weight:600;color:#1e293b;font-size:.9rem}.persona-interest{font-size:.8rem;color:#64748b}.goals-preview{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:#eef2ff;border-radius:.5rem;border:1px solid #c7d2fe}.goals-label{font-size:.75rem;font-weight:600;color:var(--primary);white-space:nowrap}.goals-text{font-size:.8rem;color:#4338ca;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-footer{margin-top:auto;padding-top:1rem;border-top:1px solid #f1f5f9}.btn-practice{width:100%;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary),#7c3aed);border:none;border-radius:.75rem;cursor:pointer;transition:all .2s}.btn-practice:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}@media(max-width:640px){.scenario-grid{grid-template-columns:1fr}.stats-summary{flex-direction:column;gap:1rem}.stat-item{padding:0}.stat-item:not(:last-child){border-right:none;border-bottom:1px solid var(--border);padding-bottom:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--dark: #1f2937;--light: #f9fafb;--text: #1f2937;--text-secondary: #6b7280;--border: #e5e7eb;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}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;color:var(--text);background-color:var(--light)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:.5rem}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{padding:.625rem 1.25rem;border-radius:.5rem;border:none;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--secondary);color:#fff}.btn-success{background-color:var(--success);color:#fff}.btn-danger{background-color:var(--danger);color:#fff}.btn-outline{background-color:transparent;border:2px solid var(--primary);color:var(--primary)}.card{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.card-header{border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text)}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.form-error{color:var(--danger);font-size:.875rem;margin-top:.25rem}.navbar{background:#fff;box-shadow:var(--shadow);padding:1rem 2rem;margin-bottom:2rem}.navbar-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:none}.navbar-brand{font-size:1.5rem;font-weight:700;color:var(--primary);text-decoration:none;display:flex;align-items:center}.navbar-logo{height:36px;width:auto;object-fit:contain}.navbar-menu{display:flex;gap:1rem;align-items:center}.navbar-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.navbar-link:hover{color:var(--primary)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background-color:var(--light)}th{padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--border)}td{padding:1rem;border-bottom:1px solid var(--border)}tr:hover{background-color:var(--light)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.badge-success{background-color:#d1fae5;color:#065f46}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.quiz-option{background:#fff;border:2px solid var(--border);border-radius:.5rem;padding:1rem;margin-bottom:1rem;cursor:pointer;transition:all .2s}.quiz-option:hover{border-color:var(--primary);background-color:#f0f1ff}.quiz-option.selected{border-color:var(--primary);background-color:#e0e7ff}.quiz-option.correct{border-color:var(--success);background-color:#d1fae5}.quiz-option.incorrect{border-color:var(--danger);background-color:#fee2e2}.level-indicator{display:flex;gap:.5rem;margin-bottom:1.5rem}.level-dot{width:40px;height:40px;border-radius:50%;background-color:var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;transition:all .3s}.level-dot.active{background-color:var(--primary);color:#fff;transform:scale(1.2)}.level-dot.completed{background-color:var(--success);color:#fff}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}.navbar-menu{flex-direction:column;gap:.5rem}}.dashboard-layout{display:flex;flex-direction:column;min-height:100vh}.dashboard-container{display:flex;flex:1}.dashboard-sidebar{width:280px;background:#fff;border-right:1px solid var(--border);padding:2rem 1rem;display:flex;flex-direction:column}.dashboard-main{flex:1;padding:2rem;background:var(--light);overflow-y:auto}.sidebar-content{position:sticky;top:2rem}.user-info{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.user-info h3{font-size:1.25rem;color:var(--primary);margin-bottom:.25rem}.user-info p{color:var(--text-secondary);font-size:.875rem}.sidebar-menu{display:flex;flex-direction:column;gap:1.5rem}.sidebar-group-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.5rem;padding-left:.75rem}.sidebar-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border:none;background:transparent;color:var(--text);font-size:.95rem;font-weight:500;border-radius:.5rem;cursor:pointer;transition:all .2s;text-align:left}.sidebar-item:hover{background-color:#f3f4f6;color:var(--primary)}.sidebar-item.active{background-color:#e0e7ff;color:var(--primary);font-weight:600}.sidebar-item .icon{font-size:1.25rem}
