swapmyface's picture
Fix teacher cards bug, professional UI overhaul
335173c verified
/* ===== Reset ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
--primary:#6C63FF;
--primary-hover:#5A52E0;
--primary-light:#EDE9FF;
--bg:#F7F7FB;
--surface:#FFFFFF;
--text:#111827;
--text2:#6B7280;
--text3:#9CA3AF;
--border:#E5E7EB;
--success:#22C55E;
--warning:#F59E0B;
--danger:#EF4444;
--r:14px;
--r-sm:10px;
--shadow-sm:0 1px 3px rgba(0,0,0,.06);
--shadow:0 4px 16px rgba(0,0,0,.06);
--shadow-lg:0 12px 40px rgba(0,0,0,.1);
--teacher-color:#6C63FF;
--teacher-light:#EDE9FF;
--font:'Inter',system-ui,-apple-system,sans-serif;
}
html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
#app{height:100%;display:flex;flex-direction:column}
.hidden{display:none!important}
/* ===== Onboarding ===== */
.onboarding{
min-height:100%;
background:linear-gradient(160deg,#1a103d 0%,#2d1b69 40%,#4c2889 100%);
display:flex;justify-content:center;
padding:32px 16px 48px;
overflow-y:auto;
}
.ob-container{
width:100%;max-width:760px;
display:flex;flex-direction:column;
}
.ob-header{text-align:center;margin-bottom:28px}
.ob-logo{
display:inline-flex;align-items:center;gap:10px;
font-size:1.7rem;font-weight:800;color:#fff;
letter-spacing:-.02em;
}
.ob-logo-icon{display:flex}
.ob-subtitle{color:rgba(255,255,255,.6);font-size:.95rem;margin-top:6px}
/* Progress */
.ob-progress{
height:4px;background:rgba(255,255,255,.12);
border-radius:4px;margin-bottom:8px;overflow:hidden;
}
.ob-progress-bar{
height:100%;background:#6C63FF;
border-radius:4px;transition:width .4s ease;
}
.ob-step-labels{
display:flex;justify-content:space-between;
margin-bottom:28px;
}
.ob-step-label{
font-size:.72rem;font-weight:600;text-transform:uppercase;
letter-spacing:.06em;color:rgba(255,255,255,.25);
transition:color .3s;
}
.ob-step-label.active{color:rgba(255,255,255,.9)}
.ob-step-label.done{color:rgba(255,255,255,.5)}
/* Steps */
.ob-step{display:none;animation:fadeUp .35s ease}
.ob-step.active{display:block}
@keyframes fadeUp{
from{opacity:0;transform:translateY(16px)}
to{opacity:1;transform:translateY(0)}
}
.ob-title{
font-size:1.5rem;font-weight:700;color:#fff;
text-align:center;margin-bottom:6px;
}
.ob-desc{
text-align:center;color:rgba(255,255,255,.55);
font-size:.9rem;margin-bottom:20px;
}
/* Language Grid */
.lang-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
gap:10px;margin-top:12px;
}
.lang-card{
background:rgba(255,255,255,.07);
backdrop-filter:blur(8px);
border:1.5px solid rgba(255,255,255,.1);
border-radius:var(--r-sm);
padding:16px 10px;text-align:center;
cursor:pointer;transition:all .2s;
user-select:none;
}
.lang-card:hover{
background:rgba(255,255,255,.12);
border-color:rgba(255,255,255,.2);
transform:translateY(-2px);
}
.lang-card.selected{
background:rgba(108,99,255,.25);
border-color:#6C63FF;
box-shadow:0 0 0 2px rgba(108,99,255,.3);
}
.lang-card .lc-flag{font-size:1.8rem;display:block;margin-bottom:4px}
.lang-card .lc-name{font-size:.88rem;font-weight:600;color:#fff;display:block}
.lang-card .lc-native{font-size:.75rem;color:rgba(255,255,255,.45);display:block;margin-top:1px}
/* Level Cards */
.level-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
gap:14px;margin-top:12px;
}
.level-card{
background:rgba(255,255,255,.07);
backdrop-filter:blur(8px);
border:1.5px solid rgba(255,255,255,.1);
border-radius:var(--r);
padding:24px;cursor:pointer;transition:all .2s;
}
.level-card:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.level-card.selected{background:rgba(108,99,255,.25);border-color:#6C63FF}
.level-card h3{color:#fff;font-size:1.15rem;margin-bottom:6px}
.level-card p{color:rgba(255,255,255,.55);font-size:.88rem;line-height:1.5}
/* Teacher Cards */
.teacher-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
gap:14px;margin-top:12px;
}
.teacher-card{
background:rgba(255,255,255,.07);
backdrop-filter:blur(8px);
border:2px solid rgba(255,255,255,.1);
border-radius:var(--r);
padding:22px;cursor:pointer;transition:all .2s;
display:flex;gap:16px;align-items:flex-start;
}
.teacher-card:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.teacher-card.selected{border-color:var(--teacher-color);background:rgba(108,99,255,.15)}
.tc-avatar{
width:64px;height:64px;min-width:64px;
border-radius:50%;overflow:hidden;
background:rgba(255,255,255,.08);
display:flex;align-items:center;justify-content:center;
}
.tc-avatar img{width:56px;height:56px}
.tc-info{flex:1;min-width:0}
.tc-name{font-size:1.05rem;font-weight:700;color:#fff}
.tc-title{font-size:.78rem;font-weight:600;color:var(--teacher-color);margin-top:1px}
.tc-style{font-size:.82rem;color:rgba(255,255,255,.5);margin-top:4px}
.tc-desc{font-size:.8rem;color:rgba(255,255,255,.4);margin-top:6px;line-height:1.4}
.btn-voice{
margin-top:8px;display:inline-flex;align-items:center;gap:4px;
padding:5px 12px;border-radius:16px;
border:1px solid rgba(255,255,255,.15);
background:transparent;color:rgba(255,255,255,.6);
font-size:.75rem;font-family:var(--font);cursor:pointer;
transition:all .2s;
}
.btn-voice:hover{border-color:var(--teacher-color);color:#fff}
/* Topic Grid */
.topic-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(155px,1fr));
gap:10px;margin-top:12px;
}
.topic-card{
background:rgba(255,255,255,.07);
backdrop-filter:blur(8px);
border:1.5px solid rgba(255,255,255,.1);
border-radius:var(--r-sm);
padding:18px 12px;text-align:center;
cursor:pointer;transition:all .2s;
}
.topic-card:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.topic-card.selected{background:rgba(108,99,255,.25);border-color:#6C63FF}
.topic-card .tc-icon{font-size:1.6rem;display:block;margin-bottom:4px}
.topic-card .tc-label{font-size:.88rem;font-weight:600;color:#fff;display:block}
.topic-card .tc-sub{font-size:.73rem;color:rgba(255,255,255,.4);display:block;margin-top:2px}
/* Buttons */
.btn-primary{
display:inline-flex;align-items:center;justify-content:center;gap:8px;
padding:14px 40px;font-size:1rem;font-weight:700;font-family:var(--font);
color:#fff;background:var(--primary);
border:none;border-radius:28px;cursor:pointer;
transition:all .2s;
box-shadow:0 4px 20px rgba(108,99,255,.35);
}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}
.btn-primary:not(:disabled):hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 28px rgba(108,99,255,.45)}
.btn-start{margin:28px auto 0;display:flex}
.btn-back{
position:fixed;bottom:24px;left:24px;
display:none;align-items:center;gap:4px;
padding:8px 16px;border-radius:20px;
background:rgba(255,255,255,.1);backdrop-filter:blur(8px);
border:1px solid rgba(255,255,255,.15);
color:rgba(255,255,255,.7);font-size:.85rem;font-weight:500;
font-family:var(--font);cursor:pointer;transition:all .2s;
}
.btn-back:hover{background:rgba(255,255,255,.18);color:#fff}
.btn-back.visible{display:inline-flex}
.btn-icon{
width:38px;height:38px;border-radius:50%;
border:none;background:transparent;
color:var(--text2);cursor:pointer;
display:flex;align-items:center;justify-content:center;
transition:all .15s;
}
.btn-icon:hover{background:var(--primary-light);color:var(--primary)}
/* ===== Lesson Layout ===== */
.lesson{
height:100%;display:flex;flex-direction:column;
background:var(--bg);
}
.lesson-header{
display:flex;align-items:center;justify-content:space-between;
padding:10px 16px;background:var(--surface);
border-bottom:1px solid var(--border);
flex-shrink:0;
}
.lh-left{display:flex;align-items:center;gap:10px}
.lh-right{display:flex;align-items:center;gap:8px}
.lh-info{display:flex;flex-direction:column}
.lh-lang{font-weight:700;font-size:.92rem}
.lh-topic{font-size:.78rem;color:var(--text2)}
.xp-pill{
display:inline-flex;align-items:center;gap:4px;
padding:4px 12px;border-radius:16px;
background:linear-gradient(135deg,#FDE68A,#F59E0B);
color:#78350F;font-size:.78rem;font-weight:700;
}
/* Avatar Strip */
.avatar-strip{
display:flex;align-items:center;gap:10px;
padding:10px 16px;background:var(--surface);
border-bottom:1px solid var(--border);flex-shrink:0;
}
.avatar-box{width:48px;height:48px;position:relative}
.avatar-box img,.avatar-box svg{width:100%;height:100%}
.avatar-label{font-weight:700;font-size:.9rem;color:var(--teacher-color)}
.avatar-box.speaking{animation:bob .45s ease-in-out infinite alternate}
@keyframes bob{from{transform:translateY(0)}to{transform:translateY(-3px)}}
/* Chat */
.chat-scroll{
flex:1;overflow-y:auto;padding:16px;
scroll-behavior:smooth;
}
.chat-inner{
display:flex;flex-direction:column;gap:10px;
max-width:680px;margin:0 auto;
}
.msg{
max-width:82%;padding:12px 16px;
border-radius:var(--r);line-height:1.6;
font-size:.92rem;word-wrap:break-word;
animation:msgIn .25s ease;
}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.msg.tutor{
align-self:flex-start;
background:var(--surface);
border:1px solid var(--border);
border-bottom-left-radius:4px;
box-shadow:var(--shadow-sm);
}
.msg.student{
align-self:flex-end;
background:var(--primary);color:#fff;
border-bottom-right-radius:4px;
}
/* Cultural Note */
.cultural-note{
background:linear-gradient(135deg,#FFFBEB,#FEF3C7);
border-left:3px solid var(--warning);
padding:10px 14px;border-radius:0 var(--r-sm) var(--r-sm) 0;
margin:8px 0;font-size:.88rem;
}
.cultural-note-title{font-weight:700;color:#B45309;font-size:.8rem;margin-bottom:3px}
/* Dialogue */
.dialogue-block{
background:var(--primary-light);border-left:3px solid var(--primary);
padding:10px 14px;border-radius:0 var(--r-sm) var(--r-sm) 0;
margin:8px 0;font-size:.88rem;
}
/* Sentence Builder */
.sentence-builder{
background:#F0FDF4;border-radius:var(--r-sm);
padding:12px 14px;margin:8px 0;
}
.sentence-builder-title{font-weight:600;font-size:.82rem;color:#166534;margin-bottom:8px}
.word-tiles{display:flex;flex-wrap:wrap;gap:6px}
.word-tile{
padding:5px 12px;background:#fff;border:2px solid #86EFAC;
border-radius:6px;cursor:grab;font-size:.88rem;
user-select:none;transition:all .15s;
}
.word-tile:hover{background:#DCFCE7}
.word-tile.placed{opacity:.35;pointer-events:none}
.sentence-drop-zone{
min-height:40px;border:2px dashed #86EFAC;
border-radius:8px;padding:6px;margin-top:8px;
display:flex;flex-wrap:wrap;gap:5px;
}
.sentence-drop-zone.correct{border-color:var(--success);background:#F0FDF4}
.placed-word{
padding:4px 10px;background:var(--success);color:#fff;
border-radius:5px;font-size:.88rem;cursor:pointer;
}
.sentence-builder-actions{margin-top:8px;display:flex;gap:6px}
.btn-check-sentence,.btn-reset-sentence{
padding:5px 14px;border-radius:6px;border:none;
font-size:.82rem;cursor:pointer;font-family:var(--font);
transition:all .15s;
}
.btn-check-sentence{background:var(--success);color:#fff}
.btn-check-sentence:hover{background:#16A34A}
.btn-reset-sentence{background:var(--border);color:var(--text2)}
/* Typing Indicator */
.typing-indicator{
align-self:flex-start;display:flex;align-items:center;gap:5px;
padding:14px 20px;background:var(--surface);
border:1px solid var(--border);
border-radius:var(--r);border-bottom-left-radius:4px;
box-shadow:var(--shadow-sm);
}
.typing-dot{
width:7px;height:7px;border-radius:50%;
background:var(--text3);
animation:bounce 1.2s ease-in-out infinite;
}
.typing-dot:nth-child(2){animation-delay:.15s}
.typing-dot:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.35}30%{transform:translateY(-5px);opacity:1}}
/* Input Dock */
.input-dock{
padding:10px 16px 14px;background:var(--surface);
border-top:1px solid var(--border);flex-shrink:0;
}
.input-row{
display:flex;align-items:center;gap:6px;
max-width:680px;margin:0 auto;
background:var(--bg);border-radius:24px;
padding:4px 6px;border:1.5px solid var(--border);
transition:border-color .2s;
}
.input-row:focus-within{border-color:var(--primary)}
.input-row input{
flex:1;border:none;background:transparent;
font-family:var(--font);font-size:.92rem;
padding:9px 8px;outline:none;color:var(--text);
}
.btn-mic{color:var(--text3)}
.btn-mic.recording{color:var(--danger);animation:pulse 1s ease infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.btn-send{color:var(--primary)}
/* ===== Responsive ===== */
@media(max-width:640px){
.onboarding{padding:20px 12px 36px}
.ob-logo{font-size:1.3rem}
.ob-title{font-size:1.2rem}
.lang-grid{grid-template-columns:repeat(auto-fill,minmax(105px,1fr))}
.level-grid,.teacher-grid{grid-template-columns:1fr}
.teacher-card{flex-direction:column;align-items:center;text-align:center}
.msg{max-width:90%}
.avatar-box{width:40px;height:40px}
}