*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,Arial,sans-serif}body{background:#eee8ff;color:#211845}.app-shell{width:min(390px,100%);min-height:100vh;margin:auto;background:#f4f0ff;box-shadow:0 0 40px #d8ccff}.auth-shell{display:grid;place-items:center;background:linear-gradient(180deg,#2b096d,#7437ff,#b250ff);padding:20px}.auth-card{width:100%;max-width:315px;background:#fff;border-radius:16px;padding:28px 18px;text-align:center}.logo{font-size:32px;font-weight:900;color:#bf5c9c}.subtitle{font-size:12px;color:#9d93b4;margin:8px 0 18px}.input-row{height:41px;margin:10px 0;display:flex;align-items:center;gap:10px;padding:0 12px;border:1px solid #e8defd;border-radius:8px;background:#faf7ff}.input-row input,.input-row select{width:100%;border:0;outline:0;background:transparent;font-size:13px}.primary-btn,.small-btn{border:0;border-radius:8px;background:linear-gradient(90deg,#7035ff,#8957f7);color:#fff;font-weight:800;cursor:pointer}.primary-btn{width:100%;height:42px}.small-btn{padding:8px 12px}.ghost-btn{width:100%;height:39px;border:1px solid #7437ff;border-radius:8px;background:#fff;color:#7437ff;font-weight:800}.link{color:#6e43f2;text-decoration:none;font-weight:800}.switch-text{font-size:12px;color:#9d93b4;margin-top:15px}.message{font-size:12px;font-weight:700;margin:10px 0}.error{color:#d93025}.success{color:#138a36}.topbar{height:86px;padding:14px;color:#fff;background:linear-gradient(120deg,#2a0870,#7237ff);display:flex;gap:10px}.coin{width:38px;height:38px;border-radius:11px;background:#ffffff22;display:grid;place-items:center}.balance h2{font-size:21px}.balance p{font-size:11px;opacity:.8}.top-actions{margin-left:auto;display:flex;gap:7px}.icon-btn,.add-btn{border:1px solid #ffffff33;background:#ffffff22;color:#fff;border-radius:999px;height:30px}.icon-btn{width:30px}.add-btn{padding:0 12px}.content{padding:14px 14px 80px}.page-head{height:60px;background:#fff;display:flex;align-items:center;gap:12px;padding:0 14px;border-bottom:1px solid #eee8ff}.back{width:32px;height:32px;border:0;border-radius:9px;background:#f6f1ff;color:#7437ff;font-size:20px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.course-card,.panel{background:#fff;border-radius:12px;padding:10px;box-shadow:0 5px 14px rgba(64,30,130,.08);margin-bottom:13px}.thumb{height:92px;border-radius:9px;background:linear-gradient(135deg,#2a0870,#ff42cc);display:grid;place-items:center;color:#fff;text-align:center;font-size:13px;font-weight:900;overflow:hidden}.course-card h4{font-size:13px;min-height:38px;margin:9px 0}.center{text-align:center}.empty{height:140px;display:grid;place-items:center;color:#b7adca;text-align:center}.empty b{display:block;font-size:38px}.menu{margin:0 14px 80px;background:#fff;border-radius:12px;overflow:hidden}.menu-item{height:52px;display:flex;align-items:center;gap:13px;padding:0 15px;border-bottom:1px solid #eee8ff;font-size:14px;cursor:pointer}.menu-icon{width:29px;height:29px;border-radius:8px;display:grid;place-items:center;background:#f0ecff}.menu-item b{margin-left:auto;color:#aa9abd}.bottom-nav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:min(390px,100%);height:62px;background:#fff;border-top:1px solid #eadfff;display:grid;grid-template-columns:repeat(4,1fr)}.nav-item{border:0;background:transparent;color:#9b91ad;font-size:11px;display:grid;place-items:center}.nav-item span{font-size:18px}.nav-item.active{color:#7437ff;font-weight:800}.invite-code{display:inline-block;margin:8px 0;padding:9px 18px;border:1px dashed #7437ff;border-radius:8px;color:#7437ff;font-weight:900}.search-line{display:grid;grid-template-columns:1fr 80px;gap:8px;margin-bottom:14px}.title-line{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}